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DP8473 Floppy Disk Controller PLUS-2™ 


General Description 


This controller is a full featured floppy disk controller that is 
software compatible with the ~PD765A, but also includes 
many additional hardware and software enhancements. 
These enhancements include additional logic specifically re- 
quired for an IBM® PC, PC-XT®, PC-AT®, or PS/2® design. 


This controller incorporates a precision analog data separa- 
tor, that includes a self trimming delay line and VCO. Up to 
three external filters are switched automatically depending 
on the data rate selected. This provides optimal perform- 
ance at the standard PC data rates of 250/300 kb/s, and 
500 kb/s. It also enables optimum performance at 1 Mb/s 
(MFM). These features combine to provide the lowest possi- 
ble PLL bandwidth, with the greatest lock range, and hence 
the widest window margin. 


This controller includes write precompensation circuitry. A 
shift register is used to provide a fixed 125 ns early-late 
precompensation for all tracks at 500k/300k/250 kb/s (83 
ns for 1 MB/s), or a precompensation value that scales with 
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Order Number DP8473V 
See NS Package Number V52A 


Features 
m@ Fully »PD765A and IBM-BIOS compatible 
@ Integrates all PCXT®, PCAT®, and most PS/2® Logic 
— On chip 24 MHz Crystal Oscillator 
— DMA enable logic 
— IBM compatible address decode of AO—A2 
— 12 mA pP bus interface buffers 
— 40 mA floppy drive interface buffers 
— Data rate and drive control registers 
@ Precision analog data separator 
— Self-calibrating PLL and delay line 
-— Automatically chooses one of three filters 
— Intelligent read algorithm 
& Two pin programmable precompensation modes 
m Other enhancements 
— up to 1 Mb/s data rate 
— Implied seek up to 4000 tracks 
— IBM or ISO formatting 
t Low power CMOS, with power down mode 


Dual-in-Line Package 
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Order Number DP8473N 
See NS Package Number N48A 
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General Description (Continued) 


the data rate, 83 ns/125 ns/208 ns/ 250 ns for data rates of 
1.0M/500k/300k/250 kb/s respectively. 


Specifically to support the PC-AT and PC-XT design, the 
Floppy Disk Controller PLUS-2 includes address decode for 
the AO-A2 address lines, the motor/drive select register, 
data rate register for selecting 250/300/500 kb/s, Disk 
Changed status, dual speed spindle motor control, low write 
current and DMA/interrupt sharing logic. The controller also 
supports direct connection to the uP bus via internal 12 mA 
buffers. The controller also can be connected directly to the 
disk drive via internal open drain high drive outputs, and 
Schmitt inputs. 


In addition to this logic the DP8473 includes many features 
to ease design of higher performance drives and future con- 
troller upgrades. These include 1.0 Mb/s data rate, extend- 
ed track range to 4096, Implied seeking, working Scan Com- 
mands, motor control timing, both standard IBM formats as 
well as Sony 3.5” (ISO) formats, and other enhancements. 
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This device is available in a 52 pin Plastic Chip Carrier, and 
in a 48 pin Dual-In-Line package. 
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Note 1: The MTR2, MTR3, DR2, and DR3 are not available on the 48 pin DIP (DP8473N, J) versions. 


Note 2: See Figure 4 for filter description. 
Note 3: Total transistor count is 29,700 (approx). 


FIGURE 1. DP8473 Functional Block Diagram 
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Pin Descriptions 
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Function 
This is an active low motor enable line for drive 2, which is controlled by the Drive Control 
register. This is a high drive open drain output. 


2 | This pin is the digital ground for the disk interface output drivers. 
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This is the active low open drain write precompensated serial data to be written onto the 
selected disk drive. This is a high drive open drain output. 


This output determines the direction of the head movement (low = step in, high = step 
out). When in the write or read modes, this output will be high. This is a high drive open 
drain output. 


This is an active low drive select line for drive 1 that is controlled by the Drive Control 
register bits DO, D1. The Drive Select bit is ANDed with the Motor Enable of the same 
number. This is a high drive open drain output. 


This is an active low drive select similar to DR1 line except for drive 0. 
This is an active low motor enable line for drive 1. Similar to MTR2. 
This is an active low motor enable line for drive 0. Similar to MTR2. 


This output determines which disk drive head is active. Low = Head 1, Open (high) = 
Head 0. This is a high drive open drain output. 


This active low Schmitt input tells the controller that the head is at track zero of the 
selected disk drive. 


This active low Schmitt input signals the beginning of a track. 


This active low Schmitt input indicates that the disk is write protected. Any command that 
writes to that disk drive is inhibited when a disk is write protected. 


This pin is the 5V supply for the analog data separator circuitry. 
This pin is the 5V supply for the digital circuitry. 


Active high input that resets the controller to the idle state, and resets all the output lines 
to the disk drive to their disabled state. The Drive Control register is reset to 00. The Data 
Rate register is set to 250 kb/s. The Specify command registers are not affected. The 
Mode Command registers are set to the default values. Reset should be held active 
during power up. To prevent glitches activating the rest sequence, a small capacitor 
(1000 pF) should be attached to this pin. 


Active low input to signal a write from the microprocessor to the controller. 
Active low input to signal a read from the controller to the microprocessor . 


Active low input to enable the RD and WR inputs. Not required during DMA transfers. 
This should be held high during DMA transfers. 


Address lines from the microprocessor. This determines which registers the 
microprocessor is accessing as shown in Table IV in the Register Description Section. 
Don’t care during DMA transfers. 


Bi-directional data lines to the RcrOprocessor. These are the lower 5 bits and have 
buffered 12 mA outputs. 


This pin is the digital ground for the 12 mA microprocessor interface buffers. This 
includes DO-D7, INT, and DRQ. 


Bi-directional data lines to the microprocessor. These upper 3 bits have buffered 12 mA 
outputs. 


Active high output to signal the DMA controller that a data transfer is needed. This signal 
is enabled when D3 of the Drive Control Register is set. 


Active low input to acknowledge the DMA request and enable the RD and WR inputs. 
This signal is enabled when D3 of the Drive Control Register is set. 


Active high input to indicate the termination of a DMA transfer. This signal is enabled 
when the DMA Acknowledge pin is active. 


Active high output to signal that an operation requires the attention of the 
microprocessor. The action required depends on the current function of the controller. 
This signal is enabled when D3 of the Drive Control Register is set. 
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Pin Descriptions (Continued) 
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Function 


This latched Schmitt input signal is inverted and routed to D7 of the data bus and is read 
when address xx7H is enabled. When the RG bit in the Mode Command is set, this pin 
functions as a Read Gate signal that when low forces the data separator to lock to the 
crystal, and when high it locks to data for diagnostic purposes. 


This pin is the digital ground for the controller's one logic, including all internal registers, 
micro-engine, etc. 


One side of the external 24 MHz evatal) is attached here. If a crystal is not used, a TTL or 
CMOS compatible clock is connected to this pin. 


One side of an external 24 MHz crystal is attached here. This pin is tied low if an external 
clock is used. 


This pin is the analog ground for the data separator, including all the PLLs, and delay 
lines. 


This pin is the output of the charge pump and the input to the VCO. One or more filters 
are attached between this pin and the GNDA, F@ND250 and FGND500 pins. 


This pin connects the PLL filter for 500k(MFM)/250k(FM) b/s to ground. This is a low 
impedance open drain output. 


This pin connects the PLL filter for 250k(MFM)/125k(FM) b/s or 300k(MFM)/150k(FM) 
b/s to ground. This is a low impedance open drain output. 


This is the same as DRO except for drive 3. 
The active low raw data read from the disk is connected here. This is a Schmitt input. 
This is the same as DRO except for drive 2. 


When the PU bit is set in Mode Command this pin is an output that indicates when the 
charge pump is making a correction. Otherwise this pin is an input that sets the precomp 
mode as shown in Table VI. If pin is configured as PUMP, PREN is assumed high. 


This is an input used by the controller to enable the 300 kb/s mode. This enables the use 
of floppy drives with either dual or single speed spindle motors. For dual speed spindle 
motors, this pin is tied low. When low, and 300 kb/s data rate is selected in the data rate 
register, the PLL actually uses 250 kb/s. This pin is tied high for single speed spindle 
motor drives (standard AT drive). When this pin is high and 300 kb/s is selected 300 kb/s 
is used. (See also RPM/LC pin). 


An external resistor connected from this pin to analog ground programs the amount of 
charge pump current that drives the external filters. The PLL Filter Design section shows 
how to determine the values. 


This active low open drain high drive output enables the write circuitry of the selected 
disk drive. This output has been designed to prevent glitches during power up and power 
down. This prevents writing to the disk when power is cycled. 


This active low open drain high drive output will produce a pulse at a software 
| «< rate to move the head during a seek operation. - 


This high drive open drain output pin has two functions based on the selection of the 
DRVTYP pin. 


1. When using a dual speed spindle motor floppy drive (DRVTYP pin low), this output is 
used to select the spindle motor speed, either 300 RPM or 360 RPM. In this mode this 
output goes low when 250/300 kb/data rate is chosen in the data rate register, and high 
when 500 kb/s is chosen. 


2. When using a single speed spindle motor floppy drive (DRVTYP pin high), this pin 
indicates when to reduce the write current to the drive. This output is high for high density 
media nen 500 kb/s is chosen). 


This is an active low motor enable line for drive 3. 
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FIGURE 2. DP8473 Typical Application 


Functional Description 


This section describes the basic architectural features of 
the DP8473, and many of the enhancements provided. Re- 
fer to Figure 7. 


765A COMPATIBLE MICRO-ENGINE 


The core of the DP8473 is a .PD765A compatible micro- 
coded engine. This engine consists of a sequencer, pro- 
gram ROM, and disk/misc registers. This core is clocked by 
either a 4 MHz, 4.8 MHz or 8 MHz clock selected in the Data 
Rate Register. Upon this core is added all the glue logic 
used to implement a PC-XT or AT, or PS/2 floppy controller, 
as well as the data separator and write precompensation 
logic. 

The controller consists of a microcoded engine that controls 
the entire operation of the chip including coordination of 
data transfer with the CPU, controlling the drive controls, 
and actually performing the algorithms associated with 
reading and writing data to/from the disk. This includes the 
read algorithm for the data separator. 


Like the PD765A, this controller takes commands and re- 
turns data and status through the Data Register in a byte 
serial fashion. Handshake for command/status |/O is pro- 
vided via the Main Status Register. All of the »PD765A 
commands are supported, as are many other enhanced 
commands. 


DATA SEPARATOR 


The internal data separator consists of an analog PLL and 
its associated circuitry. The PLL synchronizes the raw data 
signal read from the disk drive. The synchronized signal is 
used to separate the encoded clock and data pulses. The 
data pulses are de-serialized into bytes and then sent to the 
LP by the controller. 


The main PLL consists of four main components, a phase 
comparator, a filter, a voltage controlled oscillator (VCO), 
and a programmable divider. The phase comparator detects 
the difference between the phase of the divider’s output and 
the phase of the raw data being read from the disk. This 
phase difference is converted to a current which either 
charges or discharges one of the three external filters. The 
resulting voltage on the filter changes the frequency of the 
VCO and the divider output to reduce the phase difference 
between the input data and the divider’s output. The PLL is 
“locked” when the frequency of the divider is exactly the 
same as the average frequency of the data read from the 
disk. A block diagram of the data separator is shown in Fig- 
ure 3. 
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FIGURE 3. Block Diagram of DP8473’s Data Separator 
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Note: For all filter configurations, 250kb/s and 300 kb/s share the same filter. 
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FIGURE 4. Typical Configuration for Loop Filters for the DP8473 Showing Component Labels 


To ensure optimal performance, the data separator incorpo- 
rates several additional circuits. The quarter period delay 
line is used to determine the center of each bit cell. A sec- 
ondary PLL is used to automatically calibrate the quarter 
period delay line. The secondary PLL also calibrates the 
center frequency of the VCO. 


To eliminate the logic associated with controlling multiple 
data rates the DP8473 supports the connection of three 
filters to the chip via the FGND250, and FGND500 pins (fil- 
ter ground switches). The controller chooses which filter 
components to use based on the value loaded in the Data 
Rate Register. If 500 k(MFM) is being used then the 
FGND500 is enabled (FGND250 is disabled). If 250 k(MFM) 
or 300 k(MFM) is being used the FGND250 pin is enabled, 
and FGND500 is disabled. For 1 Mb/s (MFM) both FGND 
pins are disabled. 

Note for FM encoding: Sometimes, after a reset, the DP8473 will consist- 
ently return an error in the Result Phase after an FM read command. If this 
occurs, simply reset the DP8473 and retry the operation. This may have to 
be done more than once, as many as five times. Resetting and repeating will 


prevent soft errors being reported prematurely. This technique is used by 
MS-DOS. 


Figure 4 shows several possible filter configurations. For a 
filter to cover all data rates (Figure 4c ), the DP8473 has a 1 
Mb/s filter always connected and other capacitor filter com- 
ponents for the other data rates are switched in parallel to 
this filter. The actual loop filter for 500 kb/s is the parallel 
combination of the two capacitors, Coc and Cop, attached 
to the FGND500 pin and to ground. The 250/300 kb/s filter 
is the parallel combination of the capacitors, Cac and Coa, 
attached to the FGND250, and ground. If 1 Mb/s need not 
be supported then the filter configuration of Figure 4b can 
be used. This configuration allows more optimal perform- 
ance for both 500k and 250/300 kb/s. Figure 4a is a simple 
filter configuration primarily for a single data rate (or multiple 
data rates with a performance compromise). Table || shows 
some typical filter values. Other filter configurations and val- 
ues are possible, these result in good general performance. 


While the controller and data separator support both FM 
and MFM encoding, the filter switch circuitry only supports 


Functional Description (continued) 

the IBM standard MFM data rates. To provide both FM and 
MFM filters external logic may be necessary. 

The controller takes best advantage of the internal data 
separator by implementing a sophisticated ID search algo- 
rithm. This algorithm, shown in Figure 5, enhances the 
PLL's lock characteristics by forcing the PLL to relock to the 
crystal any time the data separator attempts to lock to a 
non-preamble pattern. This algorithm ensures that the PLL 
is not thrown way out of lock by write splices or bad data 
fields. 


TABLE Il. Typical Filter Values for the Various Data 
Rates (Assuming + 6% Capture Range) 


Data Rate 
(MFM b/s) 
Filter Values when Using All 3 Data Rates 


Cac = 0.012 uF | 5602 | 510pF | 5.6ka 
Cop = 0.015 pF 
250/300k | Coa = 0.033 pF 


Filter Values when Using 250/300 and 500 kb/s 
500k Cog = 0.027 pF | 5602 | 1000 pF | 5.6 kn 
250/300k | Coa = 0.047 uF | 5600 
Filter Using Only One Data Rate 
Co = 0.027 uF 


5600 | 510pF | 5.6kn 
5602 | 1000 pF | 5.6 kn 
300/250k | Co = 0.047 pF | 56029 | 2000 pF | 5.6 kn 


(These values are preliminary and thus are subject to change.) 
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TABLE III. Data Rates (MFM) versus 
VCO Divide-By Factor 


Data Rate 


1 Mb/s 
500 kb/s 
300 kb/s 
250 kb/s 


PLL DIAGNOSTIC MODES 


In addition, the DP8473 has two diagnostic modes to enable 
filter optimization, 1) enabling the Charge Pump output sig- 
nal onto the PUMP/PREN pin, and 2) providing external 
control of the Read Gate signal to the data separator. Both 
modes are enabled in the last byte of the Mode Command. 


The Pump output signal indicates when the charge pump is 
making a phase correction, and hence whether the loop is 
locked or not. 


The Read Gate function, when enabled, allows the designer 
to manually force the data separator to lock to the incoming 
data or back to the reference clock. This enables easy veri- 
fication of the lock characteristics of the PLL, by monitoring 
the FILTER pin, and the Pump signal. 


PLL FILTER DESIGN 


This section provides information to enable design of the 
data separator’s external filter and charge pump set resis- 
tor. This discussion is for a single data rate filter, and can be 
easily extrapolated to the other filters of Figure 4. Table II 
shows some typical filter component values, but if a custom 
filter is desired, the following parameters must be consid- 
ered: 


Ry: | Charge pump current setting resistor. The current 
set by this resistor is multiplied by the charge pump 
gain, Kp which is ~ 2.5. Thus the charge pump cur- 
rent is: 

IpuMp = (2.5) 1.2V/Ry. Ry should be set to between 

3-12 kQ. This resistor determines the gain of the phase 

detector, which is Kp = Ipymp/2z. 
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FIGURE 5. Read Algorithm-State Diagram for Data 
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Functional Description (Continued) 


Cy: ‘Filter capacitor in series with Ra. With pump current 
this determines loop bandwidth. 


Filter resistor. Determines the PLL damping factor. 


This filter capacitor improves the performance of the 
PLL by providing additional filtering of bit jitter and 
noise. 


The ratio of the change in the frequency of the VCO 
output due to a voltage change at the VCO input. 
Kyco ~ 25 Mrad/s/V. The VCO is followed by a di- 
vider to achieve the desired frequency for each data 
rate. VCO center frequency is 4 MHz for data rates 
of 1 Mb/s, 500 kb/s, and 250 kb/s (MFM), and is 
4.8 MHz for 300 kb/s (MFM). 

This is the gain of the internal PLL circuitry, and is 
the product of Vaer < Kyco X Kp. This value is 
specified in the Phase Locked Loop Characteristics 
table. 


This is the bandwidth of the PLL, and is given by, 


ups {Keun __ 
" 27CoN Ry 
where N is the number of VCO cycles between two 
phase comparisons. The value of N for the various 
data rates are shown in Table Ill. 
c: The damping factor is set to 0.7 to 1.2 and is given 
by, 


Ro: 
Cy: 


Kyco: 


KPLL: 


poe @nReC2 

2 
The trade off, when choosing filter components is between 
acquisition time while the PLL is locking and jitter immunity 
while reading data. To select the proper components for a 
standard floppy disk application the following procedure can 
be used: 


1. Choose FM or MFM, and data rate. Determine N from 
Table Ill. Determine preamble length (MFM = 12). The PLL 
should lock within 1/4, the preamble time. 


2. Determine loop bandwidth (wp) required, and set the 
charge pump resistor Rj. 


3. Calculate Co using: 


Co = KPLL 
277RyNon2 
4. Choose Ro using: 

2¢ 
@nCo 
6. Select C; to be about oth of Co. 


The above procedure will yield adequate loop performance. 
If optimum loop performance is required, or if the nature of 
the loop performance is very critical, then some additional 
consideration must be given to choosing w, and the damp- 
ing factor. (For a detailed description on how to choose wp, 
and ¢, see: AN-505 Floppy Disk Data Separator Design 
Guide for the DP8473). . 


WRITE PRECOMPENSATION 


The DP8473 incorporates a single fixed 3-bit shift register. 
This shift register outputs are tapped and multiplexed onto 
the write data output. The taps are selected by a standard 
precompensation algorithm. This precompensation value 
can be selected from the PUMP/PREN pin. When this pin is 


Ro = 


5-10 


low 125 ns precomp is used for all data rates except 1 Mb/s 
which uses 83 ns. When PREN is tied high, the precompen- 
sation-value scales with data rate at 250 kb/s its 250 ns, for 
300 kb/s its 208 ns, at 500 kb/s its 125 ns, and at 1.0 Mb/s 
its 83 ns. These values are shown in Table VI. 


PC-AT AND PC-XT LOGIC BLOCKS 


This section describes the major functional blocks of the PC 
logic that have been integrated on the controller. Refer back 
to Figure 1, the block diagram. 


DMA Enable Logic: This is gating logic that disables the 
DMA lines and the Interrupt output, under the control of the 
DMA Enable bit in the Drive control register. When the DMA 
Enable bit is 0 then the INT, and DRQ are held TRI-STATE, 
and DAK is disabled. 


Drive Output Buffers/Input Receivers: The drive inter- 
face output pins can drive 15002 + 10% termination resis- 
tors. This enables connection to a standard floppy drive. All 
drive interface inputs are TTL compatible schmitt trigger in- 
puts with typically 250 mV of hysteresis. 7he only functional 
differences between the 52 pin PLCC and the 48 pin DIP 
version are that the MTR2 and 3, and DR2 and 3 pins have 
been removed in order to accommodate the 48 pin pack- 
age. 

Bus Interface-Address Decode: The address decode cir- 
cuit allows software access to the controller, Drive Control 
Register, and Data Rate Register (see Table !V for the 
memory map) using the same address map as is used in the 
XT, AT, or PS/2. The decoding is provided for AO-A2, so 
only a single address decoder connected to the chip select 
is needed to complete the decode. The bus interface logic 
includes the 8-bit data bus and DRQ/INT signals. The out- 
put drive for these pins is 12 mA. 


TABLE IV. Address Memory Map for DP8473 
AO R/W 


Register 


0 0 0 X None (Bus TRI-STATE) 
0 0 1 X None (Bus TRI-STATE) 
0 1 0 WwW Drive Control Register 
0 1 1 X None (Bus TRI-STATE) 
1 0 0 R Main Status Register 
1 0 1 R/W Data Register 
1 1 0 X None (Bus TRI-STATE) 
1 1 1 W Data Rate Register 

1 1 R 


anh 


Disk Changed Bit* 


*When this location is accessed only bit D7 is driving, all others are held 
TRI-STATE. 

Drive Control Register: This 8-bit write only register con- 

trols the drive selects, motor enables, DMA enable, and Re- 

set. See Register Description. 


Reset Logic: The reset input pin is active high, and directly 
feeds the Drive Control Register and the Data Rate Regis- 
ter. After a hardware reset the Drive Control Register is re- 
set to all zeros, and the Data Rate Register is set to 
250 kb/s data rate. The controller is held reset until the 
software sets the Drive Control reset bit, after which the 
controller may be initialized. A software reset to the control- 
ler core can be issued by resetting then setting this bit. A 
software reset does not reset the Drive Control Register, or 
the Data Rate Register. 


Functional Description (continued) 


Data Rate Register and Clock Logic: This is a two bit 
register that controls the data rate that the controller uses. 
See Register Description. This register feeds logic that se- 
lects the data rates by programming a prescaler that divides 
the crystal or clock input by either 3, 5, or 6. This causes 
either 4 MHz, 4.8 MHz and 8 MHz to be input as the master 
clock for the controller core. If the Drive Type pin is high and 
a 300 kb/s data rate is chosen, 4.8 MHz is used to generate 
300 kb/s, but when the DRVTYP pin is low and 300 kb/s is 
selected, 4 MHz is used, and the actual data rate is 
250 kb/s. See Table VI. 


Low Power Mode Logic: This logic is an enhancement 
over the standard XT, AT, PS/2 design. In the Low Power 
Mode the crystal oscillator, controller and all linear circuitry 
are turned off. When the oscillator is turned off the control- 
ler will typically draw about 100 pA. The internal circuitry is 
disabled while the oscillator is off because the internal cir- 
Ccuitry is driven from this clock. The oscillator will turn back 
on automatically after it detects a read or a write to the Main 
Status or Data Registers. It may take a few milli-seconds for 
the oscillator to stabilize and the uP will be prevented from 
trying to access the Data Register during this time through 
the normal Main Status Register protocol. (The Request for 
Master bit in the Main Status Register will be inactive.) 
There are two ways to go into the low power mode. One is 
to command the controller to switch to low power immedi- 
ately. The other method is to set the controller to automati- 
cally go into the low power mode 500 ms after the beginning 
of the idle state (based on a 500 kb/s (MFM) data rate). 
This would be invisible to the software. The low power mode 
is programmed through the Mode Command. 

The Data Rate Register and the Drive Control Register are 
unaffected by the power down mode. They will remain ac- 
tive. It is up to the user to ensure that the Motor and Drive 
select signal are turned off. 


TABLE V. Truth Table for Drive Control Register 


D7 Dé D5 D4 D1 Do| Function | 


Drive 0 Selected (DRO = 0) 
Drive 1 Selected (DR1 = 0) 
Drive 2 Selected (DR2 = 0) 
Drive 3 Selected (DR3 = 0) 


Crystal Oscillator: The DP8473 is clocked by a single 
24 MHz signal. An on-chip oscillator is provided, to enable 
the attachment of a crystal, or a clock. If a crystal is used, a 
24 MHz fundamental mode, parallel resonant crystal should 
be used. This crystal should be specified to have less than 
1502 series resistance, and shunt capacitance of less than 
7 pF. Typically a series resonant crystal can be used, it will 
just oscillate in parallel mode 30-300 ppm from its ideal 
frequency. 


If an external oscillator circuit is used, it must have a duty 
cycle of at least 40-60%, and minimum input levels of 2.4V 


and 0.4V. The controller should be configured so that the 
clock is input into the OSC2 pin, and OSC1 is tied to ground. 


Crystals: Staytek: CX1-SM1-24 MHz(B) 
SaRonix: SRX 3164 


Register Description 


This section describes the register bits for all the registers 
that are directly accessible to the uP. Table IV (previous 
page) shows the memory map for these registers. Note that 
in the PC some of the registers are partially decoded, this is 
not the case here. All registers occupy only their document- 
ed addresses. 


MAIN STATUS REGISTER (Read Only) 


The read only Main Status Register indicates the current 
status of the disk controller. The Main Status Register is 
always available to be read. One of its functions is to control 
the flow of data to and from the Data Register. The Main 
Status Register indicates when the disk contoller is ready to 
send or receive data. It should be read before each byte is 
transferred to or from the Data Register except during a 
DMA transfer. No delay is required when reading this regis- 
ter after a data transfer. 


D7 Request for Master: Indicates that the Data Register is 
ready to send or receive data from the pP. This bit is 
cleared immediately after a byte transfer and will become 
set again as soon as the disk controller is ready for the next 
byte. 

D6 Data Direction: Indicates whether the controller is ex- 
pecting a byte to be written to (0) or read from (1) the Data 
Register. 


D5 Non-DMA Execution: Bit is set only during the Execu- 
tion Phase of a command if it is in the non-DMA mode. In 
other words, if this bit is set, the multiple byte data transfer 
(in the Execution Phase) must be monitored by the pP ei- 
ther through interrupts, or software polling as described in 
the Processor Software Interface section. 

D4 Command in Progress: Bit is set after the first byte of 
the Command Phase is written. Bit is cleared after the last 
byte of the Result Phase is read. If there is no result phase 
in a command, the bit is cleared after the last byte of the 
Command Phase is written. 

D3 Drive 3 Seeking: Set after the last byte of the Command 
Phase of a Seek or Recalibrate command is issued for drive 
3. Cleared after reading the first byte in the Result Phase of 
the Sense Interrupt Command for this drive. 


D2 Drive 2 Seeking: Same as above for drive 2. 
D1 Drive 1 Seeking: Same as above for drive 1. 
DO Drive 0 Seeking: Same as above for drive 0. 


DATA REGISTER (Read/Write) 


This is the location through which all commands, data and 
status flow between the CPU and the DP8473. During the 
Command Phase the »P loads the controller's commands 
into this register based on the Status Register Request for 
Master and Data Direction bits. The Result Phase transfers 
the Status Registers and header information to the jP in the 
same fashion. 
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Register Description (Continued) 


TABLE VI. Data Rate and Precompensation Programming Values 


Data Rate 
MFM 
(kb/s) 


Normal 
Precomp* 


(ns) 


sew FGND500 — 
FGND250 
FGND250 
FGND250 
FGND250 
1000 
: 1000 = 83 


Alternate FGND RPM/LC 
Precomp* Pin Pin 
(ns) Enabled Level 


None a 
None Low 


*Normal values when PUMP/PREN pin set low; Alternate values when PUMP/PREN pin set high. 


**D0 and D1 are Data Rate Control Bits. 


DRIVE CONTROL REGISTER (Write Only) 


D7 Motor Enable 3: This controls the Motor for drive 3, 
MTR3. When 0 the output is high, when 1 the output is low. 
(Note this signal is not output to a pin on 48 pin DIP 
version.) 

D6 Motor Enable 2: Same function as D7 except for drive 
2’s motor. (Note this signal is not brought out to a pin on 
DIP.) 

D5 Motor Enable 1: This bit controls the Motor for drive 1’s 
motor. When this bit is 0 the MTR1 output is high. 

D4 Motor Enable 0: Same as D5 except for drive 0’s motor. 
D3 DMA Enable: When set to a 1 this enables the DRQ, 
DAK, INT pins. A zero disables these signals. 

D2 Reset Controller: This bit when set to a 0 resets the 
controller, and when a 1 enables normal operation. It does 
not affect the Drive Control or Data Rate Registers which 
are reset only by a hardware reset. 

D1-D0 Drive Select: These two pins are encoded for the 
four drive selects, and are gated with the motor enable 
lines, so that only one drive is selected when it’s Motor En- 
able is active. (See Table V.) 


DATA RATE REGISTER (Write Only) 


D7-D2: Not used. 


D1, DO Data Rate Select: These bits set the data rate and 
the write precompensation values for the disk controller. Af- 
ter a hardware reset these bits are set to 10 (250 kb/s). 
They are encoded as shown in Table VI. 


DISK CHANGED REGISTER (Read Only) 


D7 Disk Changed: This bit is the latched complement of the 
Disk Changed input pin. If the DSKCHG input is low this bit 
is high. 

D6-D0: These bits are reserved for use by the hard disk 
controller, thus during a read of this register, these bits are 
TRI-STATE. 


Result Phase Status Registers 


The Result Phase of a command contains bytes that hold 
status information. The format of these bytes are described 
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below. Do not confuse these register bytes with the Main 
Status Register which is a read only register that is always 
available. The Result Phase status registers are read from 
the Data Register only during the Result Phase. 


STATUS REGISTER 0 (STO) 

D7-D6 Interrupt Code: 
00 = Normal Termination of Command. 
01 = Abnormal Termination of Command. Execu- 
tion of Command was started, but was not success- 
fully completed. 
10 = Invalid Command Issue. Command Issued 
was not recognized as a valid command. 
11 = Ready changed state during the polling mode. 

D5 Seek End: Seek or Recalibrate Command completed 
by the Controller. (Used during Sense Interrupt com- 
mand.) 

D4 Equipment Check: After a Recalibrate Command, 
Track 0 signal failed to occur. (Used during Sense Inter- 
rupt command.) 

D3 Not Used: 0 

D2 Head Address (at end of Execution Phase). 

D1, DO Drive Select (at end of Execution Phase). 

00 = Drive 0 selected. 01 = Drive 1 selected. 
10 = Drive 2 selected. 11 = Drive 3 selected. 


STATUS REGISTER 1 (ST1) 

D7 End of Track: Controller transferred the last byte of the 
last sector without the TC pin becoming active. The last 
sector is the End Of Track sector number programmed 
in the Command Phase. 

D6 Not Used: 0 

D5 CRC Error: If this bit is set and bit 5 of ST2 is clear, 
then there was a CRC error in the Address Field of the 
correct sector. If bit 5 of ST2 is set, then there was a 
CRC error in the Data Field. 

D4 Over Run: Controller was not serviced by the ».P soon 
enough during a data transfer in the Execution Phase. 


Result Phase Status Registers (continued) 


TABLE VII. Maximum Time Allowed to 
Service an Interrupt or Acknowledge 
a DMA Request in Execution Phase 


Data Time to 
Rate Service 


Time from rising edge of DRQ or INT to trailing edge of DAK or RD or WR. 
D3 Not Used: 0 


D2 No Data: Three possible problems: 1) Controller cannot 
find the sector specified in the Command Phase during 
the execution of a Read, Write, or Scan command. An 
address mark was found however so it is not a blank 
disk. 2) Controller cannot read any Address Fields with- 
out a CRC error during Read ID command. 3) Controller 
cannot find starting sector during execution of Read A 
Track command. 

D1 Not Writable: Write Protect pin is active when a Write 
or Format command is issued. 

DO Missing Address Mark: If bit 0 of ST2 is clear then the 
disk controller cannot detect any Address Field Address 
Mark after two disk revolutions. If bit 0 of ST2 is set then 
the disk controller cannot detect the Data Field Address 
Mark. 


STATUS REGISTER 2 (ST2) 

D7 Not Used: 0 

D6 Control Mark: Controller tried to read a sector which 
contained a deleted data address mark during execu- 
tion of Read Data or Scan commands. Or, if a Read 
Deleted Data command was executed, a regular ad- 
dress mark was detected. 

D5 CRC Error in Data Field: Controller detected a CRC 
error in the Data Field. Bit 5 of ST1 is also set. 

D4 Wrong Track: Only set if desired sector not found, and 
the track number recorded on any sector of the current 
track is different from that stored in the Track Register. 

D3 Scan Equal Hit: “Equal” condition satisfied during any 
Scan Command. 

D2 Scan Not Satisfied: Controller cannot find a sector on 
the track which meets the desired condition during Scan 
Command. 

Di Bad Track: Only set if the desired sector is not found, 
and the track number recorded on any sector on the 
track is different from that stored in the Track Register 
and the recorded track number is FF. 

DO Missing Address Mark in Data Field: Controller can- 
not find the Data Field Address Mark during Read/Scan 
command. Bit 0 of ST1 is also set. 


STATUS REGISTER 3 (ST3) 
D7 Not Used: 0 

D6 Write Protect Status 
D5 Not Used: 1 

D4 Track 0 Status 

D3 Not Used: 0 


5-13 


D2 Head Select Status 

D1, DO Drive Selected: 
00 = Drive 0 selected. 01 Drive 1 selected. 
10 = Drive 2 selected. 11 = Drive 3 selected. 


Processor Software Interface 


Bytes are transferred to and from the disk controller in dif- 
ferent ways for the different phases in a command. 


COMMAND SEQUENCE 


The disk controller can perform various disk transfer, and 
head movement commands. Most commands involve three 
separate phases. 


Command Phase: The pP writes a series of bytes to the 
Data Register. These bytes indicate the command desired 
and the particular parameters required for the command. All 
the bytes must be written in the order specified in the Com- 
mand Description Table. The Execution Phase starts imme- 
diately after the last byte in the Command Phase is written. 
Prior to performing the Command Phase, the Drive Control 
and Data Rate Registers should be set. 


Execution Phase: The disk controller performs the desired 
command. Some commands require the P to read or write 
data to or from the Data Register during this time. Reading 
data from a disk is an example of this. 


Result Phase: The pP reads a series of bytes from the data 
register. These bytes indicate whether the command exe- 
cuted properly and other pertinent information. The bytes 
are read in the order specified in the Command Description 
Table. 


A new command may be initiated by writing the Command 
Phase bytes after the last bytes required from the Result 
Phase have been read. If the next command requires se- 
lecting a different drive or changing the data rate the Drive 
Control and Data Rate Registers should be updated. If the 
command is the last command, then the software should 
deselect the drive. (Note as a general rule the operation of 
the controller core is independent of how the P updates 
the Drive Control and Data Rate Registers. The software 
must ensure that manipulation of these registers is coordi- 
nated with the controller operation.) 


During the Command Phase and the Result Phase, bytes 
are transferred to and from the Data Register. The Main 
Status Register is monitored by the software to determine 
when a data transfer can take place. Bit 6 of the Main 
Status Register must be clear and bit 7 must be set before a 


, byte can be written to the Data Register during the Com- 


mand Phase. Bits 6 and 7 of the Main Status Register must 
both be set before a byte can be read from the Data Regis- 
ter during the Result Phase. 


If there is information to be transferred during the Execution 
Phase, there are three methods that can be used. The DMA 
mode is used if the system has a DMA controller. This al- 
lows the pP to do other things during the Execution Phase 
data transfer. If DMA is not used, an interrupt can be issued 
for each byte transferred during the Execution Phase. If in- 
terrupts are not used, the Main Status Register can be 
polled to indicate when a byte transfer is required. 
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Processor Software Interface (Continued) 
DMA MODE 


If the DMA mode is selected, a DMA request will be gener- 
ated in the Execution Phase when each byte is ready to be 
transferred. To enable DMA operations during the Execu- 
tion Phase, the DMA mode bit in the Specify Command 
must be enabled, and the DMA signals must be enabled in 
the Drive Control Register. The DMA controller should re- 
spond to the DMA request with a DMA acknowledge and a 
read or write strobe. The DMA request will be cleared by the 
active edge of the DMA acknowledge. After the last byte is 
transferred, an interrupt is generated, indicating the begin- 
ning of the Result Phase. During DMA operations the Chip 
Select input must be held high. TC is asserted to terminate 
an operation. Due to the internal gating TC is only recog- 
nized when the DAK input is low. 


INTERRUPT MODE 


If the non-DMA mode is selected, an interrupt will be gener- 
ated in the Execution Phase when each byte is ready to be 
transferred. The Main Status Register should be read to ver- 
ify that the interrupt is for a data transfer. Bits 5 and 7 of the 


Command Description Table 


READ ID 
Command Phase 


READ DATA 
Command Phase 


mr |wem| sk | o | o | 1 | 4 | 0 | 


Track Number 
Drive Head Number 


Result Phase — 


Main Status Register will be set. The interrupt will be 
cleared when the byte is transferred to or from the Data 
Register. The P should transfer the byte within the time 
allotted by Table VII. If the byte is not transferred within the 
time allotted, an Overrun Error will be indicated in the Result 
Phase when the command terminates at the end of the cur- 
rent sector. 


An interrupt will also be generated after the last byte is 
transferred. This indicates the beginning of the Result 
Phase. Bits 7 and 6 of the Main Status Register will be set 
and bit 5 will be clear. This interrupt will be cleared by read- 
ing the first byte in the Result Phase. 


SOFTWARE POLLING 


If the non-DMA mode is selected and interrupts are not suit- 
able, the »P can poll the Main Status Register during the 
Execution Phase to determine when a byte is ready to be 
transferred. In the non-DMA mode, bit 7 of the Main Status 
Register reflects the state of the interrupt pin. Otherwise, 
the data transfer is similar to the Interrupt Mode described 
above. 


FORMAT A TRACK 
Command Phase 


jo |wem| ofo{+{+]o] | 
x | x [x | x | x | Ho |pRi}oRo 


Note 1 


ips} x | x | x | x | Ho |pri} Ro 


Result Phase 


Status Register 0 
Status Register 1 
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Intersector Gap Length 
Data Pattern 


Result Phase 


Command Description Table (continue) 


READ DELETED DATA 
Command Phase 


Mt (mel sk | o | 1 | 1 | 0 | 0 | 
ips| x | x | x | x | Ho |pR1[pRo 
Track Number 


Result Phase 


READ A TRACK 
Command Phase 


|o |mem| sk| o | o | o | 1 | 0 | 
ps] x | x | x | x | HD [ori] DRO 
Track Number 


Result Phase 


WRITE DATA 
Command Phase 


MT|wem|o | o | o [+ | o| 4 | 
ips} x | x | x | x | Ho [ort |pRo 


Result Phase 


WRITE DELETED DATA 
Command Phase 


MT|weml o | o | 1 | o | o[ 4 | 
ips} x | x | x | x [x0 }ort [oro 


Result Phase 
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SCAN EQUAL 
Command Phase 


Mr |Mem| sk] 1 [0 | 0 { o | 4 | 
ips] x | x | x | x | Hp |oRi/DRo 


Result Phase 


SCAN LOW OR EQUAL 

Command Phase 

it [Mem sk] +] 1 | 0] 0 | 4 | 
ips] x | x | x | x | Ho [ors] oRo| 


Result Phase 
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Command Description Table (continued) 


SENSE DRIVE STATUS 
Command Phase 


SCAN HIGH OR EQUAL 
Command Phase 


Mr |wemi sk] 1 | 4 | 4 | 0 | 4 | 
Lx | x | x | x | Ho ori} pro! 


Track Number 
Drive Head Number 


Sector Number 


Result Phase 


SEEK 
Command Phase 


pofotofolsaiijs |i] 
x | x | x | x | x | x Jori)oro| 


ree 


ES 


S 


RN 


RECALIBRATE 
Command Phase 


SENSE INTERRUPT 
Command Phase 


fofolofol{+{ofo]o 


Result Phase 


Status Register 0 
Present Track Number (PTN) 
g 


Se 


Note 2 


Result Phase 
Status Register 3 


SPECIFY 
Command Phase 


pofofo}tolojoji]s| 
| MotorOn Time DMA 


MODE 
Command Phase 


polofololojo}o|:| 
Tvl iar [ips] o [uw pR| 1 [eral 
polofol}o}lolojojo 
[1 | 4 [ 0 win] HeadSettie | 


SET TRACK 
Command Phase 


INVALID COMMAND 


Command Phase 


Invalid Op Codes 


Result Phase 


Status Register 0 
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Note 1: The IPS bit is only enabled if the IPS bit 
in the mode command is set. Otherwise this bit is 
a don’t care. 


Note 2: Shaded byte only written or read if the 
extended track range mode is enabled in the 
Mode Command (ET) = 1. 


Note 3: These commands are additional en- 
hanced commands. 


Note: Mnemonic Definitions 
X = DON’T CARE 
MFM = Data Encoding Scheme 


MSN PTN = Most Significant Nibble Present 
Track Number 


MT = Multi-Track 


IPS = Implied Seek (In individual commands this 
bit is a don’t care unless the IPS bit in the mode 
command is set.) 


SK = Skip Sector 

HD = Head Number 

DRn = Drive to Select (encoded) 
TMR = Motor/Head Timer Mode 
IAF = Index Address Field 

LW PR = Low Power Mode 

ETR = Extended Track Range 
WLD = Wildcard in Scan 


RG = Enables the Read Gate Input on the 
DSKCHG pin for the Data Separator. 


PU = Enables Charge Pump PUMP signal to be 
output on the PUMP/PREN pin. 


MSB = Selects whether the most significant or 
least significant byte of the track is read. 1 = 
MSB. 


R/W = Selects whether the track is written or 
read (Read = 0, Write = 1). 


Command Description 


READ DATA 


The Read Data op-code is written to the data register fol- 
lowed by 8 bytes as specified in the Command Description 
Table. After the last byte is written, the controller starts 
looking for the correct sector header. Once the sector is 
found the controller sends the data to the pP. After one 
sector is finished, the Sector Number is incremented by one 
and this new sector is searched for. If MT (Multi-Track) is 
set, both sides of one track can be read. Starting on side 
zero, the sectors are read until the sector number specified 
by End of Track Sector Number is reached. Then, side one 
is read starting with sector number one. 


In DMA mode the Read Data command continues to read 
until the TC pin is set. This means that the DMA controller 
should be programmed to transfer the correct number of 
bytes. TC could be controlled by the wP and be asserted 
when enough bytes are received. An alternative to these 
methods of stopping the Read Data command is to program 
the End of Track Sector Number to be the last sector num- 
ber that needs to be read. The controller will stop reading 
the disk with an error indicating that it tried to access a 
sector number beyond the end of the track. 


The Number of Data Bytes per Sector parameter is defined 
in Table Vill. If this is set to zero then the Data Length 
parameter determines the number of bytes that the control- 
ler transfers to the pP. If the data length specified is smaller 
than 128 the controller still reads the entire 128 byte sector 
and checks the CRC, though only the number of bytes spec- 
ified by the Data Length parameter are transferred to the 
pP. Data Length should not be set to zero. If the Number of 
Bytes per Sector parameter is not zero, the Data Length 
parameter has no meaning and should be set to FF (hex). 


If the Implied Seek Mode is enabled by both the Mode com- 
mand and the IPS bit in this command, a Seek will be per- 
formed to the track number specified in the Command 
Phase. The controller will also wait the Head Settle time if 
the implied seek is enabled. 


After all these conditions are met, the controller searches 
for the specified sector by comparing the track number, 
head number, sector number, and number bytes/sector giv- 
en in the Command Phase with the appropriate bytes read 
off the disk in the Address Fields. 


If the correct sector is found, but there is a CRC error in the 
Address Field, bit 5 of ST1 (CRC Error) is set and an abnor- 
mal termination is indicated. If the correct sector is not 


found, bit 2 of ST1 (No Data) is set and an abnormal termi- 
nation is indicated. In addition to this, if any Address Field 
track number is FF, bit 1 of ST2 (Bad Track) is set or if any 
Address Field track number is different from that specified in 
the Command Phase, bit 4 of ST2 (Wrong Track) is set. 


After finding the correct sector, the controller reads that 
Data Field. If a Deleted Data Mark is found and the SK bit is 
set, the sector is not read, bit 6 of ST2 (Control Mark) is set, 
and the next sector is searched for. If a deleted data mark is 
found and the SK bit is not set, the sector is read, bit 6 of 
ST2 (Control Mark) is set, and the read terminates with a 
normal termination. If a CRC error is detected in the Data 
Field, bit 5 is set in both ST1 and ST2 (CRC Error) and an 
abnormal termination is indicated. 


If no problems occur in the read command, the read will 
continue from one sector to the next in logical order (not 
physical order) until either TC is set or an error occurs. 


If a disk has not been inserted into the disk drive, there are 
many opportunities for the controller to appear to hang up. It 
does this if it is waiting for a certain number of disk revolu- 
tions for something. If this occurs, the controller can be 
forced to abort the command by writing a byte to the Data 
register. This will place the controller into the Result Phase. 


TABLE Vill. Sector Size Selection 


Number 
of Bytes in 
Data Field 


Bytes/Sector 
Code 


An interrupt will be generated when the Execution Phase of 
the Read Data command terminates. The values that will be 
read back in the Result Phase are shown in Table IX. If an 
error occurs, the result bytes will indicate the sector being 
read when the error occurred. 


READ DELETED DATA 


This command is the same as the Read Data command 
except for its treatment of a Deleted Data Mark. If a Deleted 


TABLE IX. Result Phase Termination Values with No Error 


MT Last ID information at Result Phase 


0 
0 
0 
0 
4 
1 
1 
1 


EOT = End of Track Sector Number from Command Phase 


NC = No Change in Value 


S = Sector Number last operated on by controller 
T = Track Number programmed in Command Phase 
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Command Description (Continued) 


Data Mark is read, the sector is read normally. If a Regular 
Data Mark is found and the SK bit is set, the sector is not 
read, bit 6 of ST2 (Control Mark) is set, and the next sector 
is searched for. If a Regular Data Mark is found and the SK 
bit is not set, the sector is read, bit 6 of ST2 (Control Mark) 
is set, and the read terminates with a normal termination. 


WRITE DATA 


The Write Data command is very similar to the Read Data 
command except that data is transferred from the uP to the 
disk rather than the other way around. If the controller de- 
tects the Write Protect signal, bit 1 of ST1 (Not Writable) is 
set and an abnormal termination is indicated. 


WRITE DELETED DATA 


This command is the same as the Write Data Command 
except a Deleted Data Mark is written at the beginning of 
the Data Field instead of the normal Data Mark. 


READ A TRACK 


This command is similar to the Read Data command except 
for the following. The controller starts at the index hole and 
reads the sectors in their physical order, not their logical 
order. 


Even though the controller is reading sectors in eae physi- 
cal order, it will still perform a comparison of the header ID 
bytes with the Data programmed in the Command Phase. 
The exception to this is the sector number. Internally, this is 
initialized to a one, and then incremented for each succes- 
sive sector read. Whether or not the programmed Address 
Field matches that read from the disk, the sectors are still 
read in their physical order. If a header ID comparison fails, 
bit 2 of ST1 (No Data) is set, but the operation will continue. 
If there is a CRC error in the Address Field or the Data Field, 
the read will also continue. 


The command will terminate when it has read the number of 
sectors programmed in the EOT parameter. 


READ ID 


This command will cause the controller to read the first Ad- 
dress Field that it finds. The Result Phase will contain the 
header bytes that are read. There is no data transfer during 
the Execution Phase of this command. An interrupt will be 
generated when the Execution Phase is completed. 


FORMAT A TRACK 


This command will format one track on the disk. After the 
index hole is detected, data patterns are written on the disk 
including all gaps, address marks, Address Fields, and Data 
Fields. The exact details of the number of bytes for each 
field is controlled by the parameters given in the Format A 
Track command, and the IAF (Index Address Field) bit in the 
Mode command. The Data Field consists of the Fill Byte 
specified in the command, repeated to fill the entire sector. 


To allow for flexible formatting, the .P must supply the four 
Address Field bytes (track, head, sector, number of bytes) 
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for each sector formatted during the Execution Phase. In 
other words, as the controller formats each sector, it will 
request four bytes through either DMA requests or inter- 
rupts. This allows for non-sequential sector interleaving. 
Some typical values for the programmable GAP size are 
shown in Table X. 


The Format Command terminates when the index hole is 
detected a second time, at which point an interrupt is gener- 
ated. Only the first three status bytes in the Result Phase 
are significant. 


TABLE X. Gap Length for Various Sector Sizes 
and Disk Types 


Sector | Sector Format 
=~ Se 


8” Drives ed RPM, 500 kb/s) 


5.25” Drives a RPM, 250 | ———«B.25" Drives (300 RPM, 250kb/s) 


i 
01 
02 
03 
04 
01 
01 
02 
03 
04 
05 


OF 07 
09 0E 
05 


OF 
09 
05 


Note: Format Gap is the gap length used only for the Format command. 


Command Description (Continued) 


INDEX PULSE 


T 
R 
A 
Cc 
K 


o 
o 
| ee 
mau 
XRQPYrae 


INDEX ADDRESS 
FIELD 


FM 


FORMAT re) 


GAP SYNC 
32 OF | 12 OF 
MFME 4 00 


3 OF 
Al* 


Notes: 


FE* = Data pattern of FE, Clock pattern of C7 
FC* = Data pattern of FC, Clock pattern of D7 
FB* = Data pattern of FB, Clock pattern of C7 
F8* = Data pattern of F8, Clock pattern of C7 
Ai* = Data pattern of A1, Clock pattern of 0A 
C2* = Data pattern of C2, Clock pattern of 14 


DBOAGSMW” 


ADDRESS FIELD + DATA FIELD 


amo < Ws: 


DATA GAP 
PROGRAM 
ABLE 


REPEATED FOR EACH SECTOR 


GAP SYNC 
11 OF 6 OF 
FF 00 


GAP SYNC aM | 
22 OF | 12 OF 
4e 00 Fi 
0 
Fi 
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All byte counts in decimal. 
All byte values in hex. 
CRC uses standard polynomial x16 + x12.+ x5 + 1, 


FIGURE 6. IBM and ISO Formats Supported by the Format Command 


SCAN COMMANDS 


The Scan Commands allow data read from the disk to be 
compared against data sent from the wP. There are three 
Scan Commands to choose from: 


Scan Equal Disk Data = uP Data 


Scan Less Than or Equal Disk Data < pP Data 
Scan Greater Than or Equal Disk Data = p»P Data 


Each sector is interpreted with the most significant bytes 
first. If the Wildcard mode is enabled from the Mode com- 
mand, an FF(hex) from either the disk or the P is used as a 
don’t care byte that will always match equal. After each sec- 
tor is read, if the desired condition has not been met, the 
next sector is read. The next sector is defined as the current 
sector number plus the Sector Step Size specified. The 
Scan command will continue until the scan condition has 
been met, or the End of Track Sector Number has been 
reached, or if TC is asserted. 
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If the SK bit is set, sectors with deleted data marks are 
ignored. If all sectors read are skipped, the command will 
terminate with D3 of ST2 set (Scan Equal Hit). The result 
phase of the command is shown in Table XI. 


TABLE XI. Scan Command Termination Values 


Status 
Register2 _ 


Disk = wP 
Disk * wP 
Disk = uP 
Disk < pP 
Disk > uP 
Disk = pP 


Disk > wP 
Disk < pP 


Scan Low 
or Equal 


Scan High 
or Equal 
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Command Description (Continued) 
SEEK 


There are two ways to move the disk drive head to the 
desired track number. Method One is to enable the Implied 
Seek Mode. This way each individual Read or Write com- 
mand will automatically move the head to the track speci- 
fied in the command. 


Method Two is using the Seek Command. During the Execu- 
tion Phase of the Seek Command, the track number to seek 
to is compared with the present track number and a step 
pulse is produced to move the head one track closer to the 
desired track number. This is repeated at the rate specified 
by the Specify Command until the head reaches the correct 
track. At this point an interrupt is generated and a Sense 
Interrupt Command is required to clear the interrupt. 


During the Execution Phase of the Seek Command the only 
indication via software that a Seek Command is in progress 
is bits 0-3 (Drive Busy) of the Main Status Register. Bit 4 of 
the Main Register (Controller Busy) is not set. While the 
internal microengine is capable of multiple seeks on 2 or 
more drives at the same time since the drives are selected 
via the Drive Control Register in software, software should 
ensure that only one drive is seeking at one time. No other 
command except the Sense Interrupt Command should be 
issued while a Seek Command is in progress. 


If the extended track range mode is enabled, a fourth byte 
should be written in the Command Phase to indicate the 
four most significant bits of the desired track number. Other- 
wise, only three bytes should be written. 


RECALIBRATE 


The Recalibrate Command is very similar to the Seek Com- 
mand. It is used to step a drive head out to track zero. Step 
pulses will be produced until the track zero signal from the 
drive becomes true. If the track zero signal does not go true 
before 77 step pulses are issued, an error is generated. If 
the extended track range mode is enabled, an error is not 
generated until 3917 pulses are issued. 

Recalibrations on more than one drive at a time should not 
be issued for the same reason as explained in the Seek 
Command. No other command except the Sense Interrupt 


Command should be issued while a Recalibrate Command 


is in progress. 


SENSE INTERRUPT STATUS 


An interrupt is generated by the controller when any of the 
following conditions occur: 


1. Upon entering the Result Phase of: 
. Read Data Command 
. Read Deleted Data Command 
. Write Data Command 
. Write Deleted Data Command 
. Read a Track Command 
Read ID Command 
. Format Command 
. Scan Commands 


2. During data transfers in the Execution Phase while in the 
Non-DMA mode 


3. Internal Ready signal changes state (only occurs imme- 
diately after a hardware or software reset). 


4. Seek or Recalibrate Command termination 


An interrupt generated for reasons 1 and 2 above occurs 
during normal command operations and are easily discern- 


s,aQq ~~ oO aodao ® 
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ible by the uP. During an execution phase in Non-DMA 
Mode, bit 5 (Execution Mode) in the Main Status Register is 
set to 1. Upon entering Result Phase this bit is set to 0. 
Reasons 1 and 2 do not require the Sense Interrupt Status 
command. The interrupt is cleared by reading or writing in- 
formation to the data register. 


Interrupts caused by reasons 3 and 4 are identified with the 
aid of the Sense Interrupt Status Command. This command 
resets the interrupt when the command byte is written. Use 
bits 5, 6 and 7 of STO to identify the cause of the interrupt as 
shown in Table XIl. 


TABLE XII. Status Register 0 Termination Codes 


Status Register 0 
Interrupt Seek 
Sa End 


peter a er 
fo | 0 | 14 | Normalseek Termination | 
| o | 1 | 14 | Abnormal Seek Termination | 


TABLE XIll. Step, Head Load and Unload Timer 
Definitions (500 kb/s MFM) 


ee ale wae st 


Step Rate (16 —N)| 1-16 | (16—N)] 1-16 
Head Unload is xX 16 | 0-240 : x 512 | O-7680 
Head Load NX 2 | 0-254] N xX 32 | 0-4064 


Issuing a Sense Interrupt Status Command without an inter- 
rupt pending is treated as an invalid command. 


If the extended track range mode is enabled, a third byte 
should be read in the Result Phase which will indicate the 
four most significant bits of the Present Track Number. Oth- 
erwise, only two bytes should be read. 


SPECIFY 


The Specify Command sets the initial values for each of the 
three internal timers. The timer programming values are 
shown in Tabie Xill. 


The Head Load and Head Unload timers are artifacts of the 
uPD765A. These timers determine the delay from loading 
the head until a read or write command is started, and un- 
loading the head sometime after the command was com- 
pleted. Since the DP8473’s head load signal is now the soft- 
ware controlled Motor lines in the Drive Control Register, 
these timers only provide some delay from the initiation of a 
command until it is actually started. These times can be 
extended by setting the TMR bit in the Mode Command. 


The Step Rate Time defines the time interval between adja- 
cent step pulses: during a Seek, Implied Seek, or Recali- 
brate Command. 


The times stated in the table are affected by the Data Rate. 
The values in the table are for 500 kb/s MFM (250 kb/s FM) 
and 1 Mb/s MFM (500 kb/s FM). For a 300 kb/s MFM data 
rate (150 kb/s FM) these values should be multiplied by 
1.6667, and for 250 kb/s MFM (125 kb/s FM) these values 
should be doubled. 


The choice of DMA or Non-DMA operation is made by the 
NON-DMA bit. When this bit is 1 then Non-DMA mode is 
selected, and when this bit is 0, the DMA mode is selected. 


This command does not generate an interrupt. 


Cause 


Timer 


Command Description (continua) 
LOW PWR (LOW PoWeR mode) 


SENSE DRIVE STATUS 


This two byte command obtains the status of a disk drive. 
Status Register 3 is returned in the result phase and con- 
tains the drive status. This command does not generate an 
interrupt. 


MODE 


This command is used to select the special features of the 
controller. The bits for the command phase bytes are shown 
in the command description table, and their function is de- 
scribed below. The defaults after a hardware or software 
reset are shown by the “bullets” to the left of each item. 


¢ TMR=0 (motor TiMeR): Timers for motor on and motor 
off are defined for Mode 1. (See Specify Command) 
TMR = 1: Timers for motor on and motor off are defined 
for Mode 2. (See Specify Command) 


LW PR (LoW PoweR) 
¢ 00 Completely disable the low power mode. (default) 


01 Go into low power mode 500 ms after the head un- 
load timer times out. 


10 Go into low power mode now. 
11 Not Used. 


IAF =0 (Index Address Format): The controller will for- 
mat tracks with the Index Address Field included. (IBM 
Format) 


IAF = 1: The controller will format tracks without includ- 
ing the Index Address Mark Field. (ISO Format) 


IPS = 0 (ImPlied Seek): The implied seek bit in the com- 
mand is ignored. 


IPS= 1: The implied seek bit in the command is enabled 
so that if the bit is set in the command, a Seek will be 
performed automatically. 


ETR=0 (Extended Track Range): Header format is the 
IBM System 34 (double density) or System 3740 (single 
density). 


ETR = 1: Header format is the same as above but there 
are 12 bits of track number. The MSB’s of the track num- 
ber are in the upper four bits of the head number byte. 


WLD=0 (scan WILD card): An FF(hex) from either the 
BP or the disk during a Scan Command is interpreted as 
a wildcard character that will always match true. 


WLD = 1: The Scan commands do not recognize FF(hex) 
as a wildcard character. 


Head Settle: Time allowed for head to settle after an 
Implied Seek. Time = N X 4 ms, (0 ms—60 ms). (Based 
on 500 kb/s and 1 Mb/s MFM data rates. Double for 
250 kb/s.) 


PU (PUMP Pulse Output): When set enables a signal 
that indicates when the Data Separator’s charge pump is 
making a phase correction. This is a series of pulses. This 
signal is output on the PUMP/PREN pin when this bit is 
set. 


This is intended as a test mode to aid in evaluation of the 
Data Separator. (Default mode is off) 


RG (Read Gate): Like the PUMP output, when this bit is 
set it enables a pin (the DSKCHG pin) to act as an exter- 
nal Read Gate signal for the Data Separator. This is in- 
tended as a test mode to aid in evaluation of the Data 
Separator. (Default mode is off) 


SET TRACK 


This command is used to inspect or change the value of the 
internal Present Track Register. This could be useful for re- 
covery from disk mis-tracking errors, where the real current 
track could be read through the Read ID command and then 
the Set Track Command can set the internal present track 
register to the correct value. 


The first byte of the command contains the command op- 
code and the R/W bit. If the R/W bit is low, a track register 
is to be read. In this case, the result phase contains the 
value in the internal register specified, and the third byte of 
the command is a dummy byte. 


If the R/W bit is high, data is written to a track register. In 
this case the 3rd byte of the command phase is forced into 
the specified internal register, and the result phase contains 
the new byte value written. 


The particular track register chosen to operate on is deter- 
mined by the least significant 3 bits of the second byte of 
the command. The two LSB’s select the drive (DR1, DRO), 
and the next bit (MSB) determines whether the least signifi- 
cant byte (MSB=0) or the most significant byte (MSB= 1) 
of the track register is to be read/written. When not in the 
extended track range mode, only the LSB track register 
need be updated. In this instance, the MSB bit is set to 0. 


This command does not generate an interrupt. 


INVALID COMMAND 


If an invalid command (i.e., a command not defined) is re- 
ceived by the controller, the controller will respond with STO 
in the Result Phase. The Controller does not generate an 
interrupt during this condition. Bits 6 and 7 in the Main 
Status Register are both set to one’s indicating to the proc- 
essor that the Controller is in the Result Phase and the 
contents of STO must be read. When the system reads STO 
it will find an 80(hex) indicating an invalid command was 
received. 


Typical Performance Characteristics 


Typical Window Margin Performance 
ler actotistics at 250 kb/s MFM 


WINDOW MARGIN PERCENTAGE 


40% 
712% -8% -4% 0% 4% 8% 12% 
MOTOR SPEED VARIATION (% OF NOMINAL) 
TL/F/9384—18 
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Typical Window Margin Performance 
Characteristics at 500 kb/s MFM 


WINDOW MARGIN PERCENTAGE 


40% 
“12% =8% =-4% 0% 
MOTOR SPEED VARIATION (% OF NOMINAL) 


4% «68% «12% 


TL/F/9384-19 
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Absolute Maximum Ratings (Notes1and2) Operating Conditions 


If Military/Aerospace specified devices are required, Min Max Units 
please contact the National Semiconductor Sales Supply Voltage (Vcc) 45 55 V 
Office/Distributors for availability and specifications. 
Supply Voltage (Vcc) _0.5Vto +7V Operating Temperature (Ta) 0 +70 °C 
DC Input Voltage (Vin) —0.5V to Voc + 0.5V ESD Tolerance:Czap = 100pF gg : 
DC Output Voltage (Vout) —0.5V to Voc + 0.5V Rzap = 1.5k0 
Storage Temperature Range (Tstq) —65°C to + 165°C (Note 5) 
Package Power Dissipation (Pp) 750 mW 
Lead Temperature (T_) 

(Soldering, 10 seconds) 260°C 
lVcc-Vecal 0.6V 


DC Electrical Characteristics vo, = 5v + 10% unless otherwise specified (Note 3) 


symbol Conditions | Min | Max__| Units 
Vin High Level Input Voltage (except OSC2/CLK) | a0 
Vit Low Level Input Voltage (except OSC2/CLK) | 


IN _ Input Current (except OSC pins) Vin = Voc or GND ee et +1.0 pA 


< 


ICCA Average Voca Supply Current Vin = 2.4V or 0.5V, lo = OMA 
| (Note 4) 

Quiescent Vcca Supply Current Vin = Voc or GND, lo = OMA 
in Low Power Mode (Note 4) 

loc Average Vcc Supply Current Vin = 2.4V or 0.5V, lo = OMA 
(Note 4) 

Quiescent Vcc Supply Current Vin = Voc or GND, lo = O mA 
in Low Power Mode (Note 4) 


OSCILLATOR PINS (OSC2/CLK) 


MICROPROCESSOR INTERFACE PINS (D0-D7, INT, DAK, TC, DRQ, RD, WR, CS, AO0-A3) 


High Level Output Voltage lout = —20 pA Voc — 0.1 
lout = —4.0mA 3.5 
__ Low Level Output Voltage louT = 20 pA 0.1 
| lout = 12 mA | 0.4 
Output TRI-STATE® Leakage Vout = Vcc or GND 
Current ; 


DISK DRIVE INTERFACE PINS 
(MTRO-3, DRO-3, WDATA, WGATE, RDATA, DIR, HDSEL, TRKO, WRTPRT, RPM, STEP, DSKCHG, INDEX) 


Vu | tnputtysteresis | 80 Typical |v 
Vor | LowLevelOutput Voltage | lour=48maA || 
luxe | OutputHigh Leakage Curent [| Vour=VocorgnD | | #100 | 
Vin | Hightevelinputvotage | ee | 
Mu | Lowtevelinputvotage | 


Note 1: Absolute Maximum Ratings are those values beyond which damage to the device may occur. 

Note 2: Unless otherwise specified all voltages are referenced to ground. 

Note 3: These DC Electrical Characteristics are measured staticly, and not under dynamic conditions. 

Note 4: Icc is measured with a 0.1 wF supply decoupling capacitor to ground. 

Note 5: Value based on test complying with NSC SOP5-028 human body model ESD testing using the ETS-910 tester. 


4 
> 


+1.6 
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Phase Locked Loop Characteristics Voc = 5V +10%, Fyta_ = 24 MHz unless otherwise specified 


Symbol 
VREF 


Kvco 
Ry 


Kp(up) 
Kp(OWN) 


KPLL 


Tsw 


Tpw 


Conditions 


SETCUR Pin Reference Ry = 5.6k9, Voc = 5V 
Voltage 


VCO Gain (Note 5) 
Recommended Pump 

Resistor Range | 

Charge Pump Up Current Ry = 56k 

Gain (IREF/Ip(ypy) (Note 6) 

Charge Pump Down Current Ry = 5.6k9 

Gain (IREF/|Ipiown)) (Note 6) 

Internal Phase Locked Loop 
Gain (Note 7) 


(Ry = 5.6 k0) 


Pump Up 
Pump Down 


Static Window 
(Note 8) 


(Ry = 5.6 kQ) 
250 kb/s 
500 kb/s 

1.0 Mb/s 


Dynamic Window (Note) 
Margin | 


° 
=—h 


Ty 


me 


NON 
ou 


1075 872 
530 440 
259 234 


~J 


Units 
V 
Mrad/s/V 


kn 
(none) 


(none) 


Mrad 
Mrad 


ns 
ns 
ns 


% 


Note: Measurements made with a repeating ‘DB6” data pattern with reverse write precompensation, using recommended filter values for the configuration shown 
in Figure 4c. 25°C, 5.0V, 0% MSV. 
Note 5: The VCO gain is measured at the 1.0 Mb/s data rate by forcing the data period over a range from 900 ns to 1100 ns, and measuring the resulting voltage 
on the filter pin. The best straight line gain is fit to the measured points. 
Note 6: This is the current gain of the charge pump, which is defined as the output current divided by the current through Ry. 
Note 7: This is the product of: Vaer < Kp < Kyco. The total variation in this specification indicates the total loop gain variation contributed by the internal circuitry. 
The Kyco portion of this specification is measured at the 1.0 Mb/s data rate by forcing the data period over a range of 900 ns to 1100 ns, and measuring the 
resultant Kyco. Kp is measured by forcing the Filter pin to 2.1V and measuring the ratio of the charge pump current over the input current. 


Note 8: The DP8473 is guaranteed to correctly decode a single shifted clock pulse at the end of a long series of non-shifted preamble bits as long as the single 
shifted pulse is shifted less than the amount specified in Tgw. The length of the preamble is long enough for the PLL to lock. The filter components used are those 


in Table Il. 
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AC Electrical Characteristics 
MICROPROCESSOR READ TIMING 


A0=A2,DAK 


CS,RD 


DO=D7 VALID DATA 
ia tri 


INT 
TL/F/9384-11 


symbol | Parameter =| SS Min’ =~ |= Max | Units 
tan [Address ValidpriortoReadStobe = | 10S | S| ts 
tRA | _AddressHoldfromReadStobe | | | 
tan | ReadStobewidth | Tt 
tab | _ReadStrobeandChipSelecttoDataVaid | | S75 | 
taDR | Address ValidtoReadData =| | | 
(TRI-STATE Note) 
ta [_GlearNTfromReadStobe | TT 


TRI-STATE Note: This limit includes the RC delay inherent in our test method. This signal will typically turn off within 15 ns, enabling other devices to drive this 
signal with no contention. 


MICROPROCESSOR WRITE TIMING 


A0=A2,DAK 


DO=D7 VALID DATA 
ene twi 


INT 
TL/F/9384-12 


symbol | Parameter, =| Min’ =| Max | Units 
taw | Address ValidtoLeadingEdge of WriteStobe | 10 | |g 
twa | AddressHoldfromWrteStobe | | | 
ww | WriteStobewith =| | 
trow | __—Address Valid to Trailing Edge of WriteStobe | 85 | ns 
tow | _DataSetuptoEndof Write Strobe or Chip Select | 20 | |g 
twp Data Hold from Write Strobe a ns 
tw | GlearinTfromwritestobe | | ts 
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AC Electrical Characteristics (continued) 
OSC2/CLOCK AND RESET TIMING 


- ty + tL ¥ 
CLOCK 

an Cl 
RESET 


Symbol || Parameter | Min, =| Max 
, | Glookigh Time | te | ns 
t | GlocktowTime | te ns 
ta | _ResetPusewieth | 00, | 
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Units 


ns 
DMA TIMING (Note 9) 
DRQ 
tag 
t aa 
DAK 
toa 
RD OR WR 
tar 
tia tr 
TC 


TL/F/9384-14 


| Max | units 
ns 


ns 


Symbol | Parameter | Min 
tna | Endof DRQfromDAK | 
tan |___DAKAssertiontromoRQ | to | 

tAA | dakPusewin | 5 | 
ton | __DRQtoReadorwitestobe | to || 
trr | _Tosrobewatn | so | 


Note 9: DMA Acknowledge is sufficient to acknowledge a data transfer. Read or Write Strobes are neccessary only if data is to be presented to the data bus. If 
Read/Write Strobes are applied, then they and the Acnowledge must be removed within 1 ys of each other. 


Note 10: TC is is the terminal count t pin which terminates the data transfer operation. There are several constraints placed on the timing of TC. 1) TC is enabled by 
DAK, so TC must be pulsed while DAK is low. 2) TC must occur before ((1/data rate x 8) — 1 ys). Data rate is the exact data transfer rate being used. 


DRIVE READ TIMING 
e. Anne 5 
trow a - 


TL/F/9384-15 


Read Data Pulse Width 
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AC Electrical Characteristics (Continued) 
DRIVE WRITE TIMING 


DP8473 


HDSEL 
|-twos—| L-tuon-»| 
WGATE | 
poe (NOTE 11) +-—+ (NOTE 11) 
WDATA 


twp —| }— 
TL/F/9384-16 
Conditions | Min | Max | 


twp Write Data Pulse Width 250 kb/s (MFM) ns 
300 kb/s (MFM) ns 
500 kb/s (MFM) 


1000 kb/s(MFM) 


Head Select Setup to Write Gate Assertion Pg 
Head Select Hold from Write Gate a (aE ae eee 


Note 11: Whenever WGATE is asserted the WDATA line is active. At the end of each write one dummy byte is written before WGATE is deasserted. 
DRIVE TRACK ACCESS TIMING 


INDEX 
wo 
WR 
eo t orv t orv — few 
DRO=3,MTRO=3 
DIR 
4 t ost—>| |< PROGRAMMABLE >\e— toy — 
STEP 


fot 


TL/F/9384-17 


symbol | Parameter =| Min. =| Max | Units 
tosr___|_DirectionSetupprirtoStep = | | ns 
ton ___|_DirectionHoldfromEndof Step | tsteptime | 

tsp | StepPulsewth =| Ts 
tw | indexPulsewidth =| to | | 
torv Drive Select or Motor Time from Write Strobe PL t0 ns 
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AC Test Conditions (notes 11, 12, 13) 


Input Pulse Levels GND to 3V 
input Rise and Fall Times 6ns 


Input and Output Reference Levels 1.3V 
TRI-STATE Reference Levels Active High — 0.5V 
Active Low + 0.5V 


Note 11: C, = 100 pF, includes jig and scope capacitance. 


Note 12: S1 = open for push-pull outputs. S1 = Vcc for high impedance to 
active low and active low to high impedance measurements. S1 = GND for 
high impedance to active high and active high to high imepedance measure- 
ments. RL = 1.0 kf. for uP interface pins. 


Note 13: For the Open Drain Drive Interface Pins S1 = Vcc and Ry = 
1500. 


Vec 


DEVICE 
UNDER 
TEST 


Capacitance 1, = 25°C, f = 1 MHz (Note 14) 


Note 14: This parameter is not 100% tested. 


TL/F/9384-20 
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1.0 INTRODUCTION 


Due to the increase in CMOS processing capabilities it is 
now possible to integrate both the analog and digital circuit- 
ry to achieve a high performance monolithic. data separator. 
The choice of CMOS technology also enables the integra- 
tion of an analog data separator function with good perform- 
ance onto a floppy disk controller, resulting in National’s 
DP8473 integrated floppy data separator/controller. 


This paper discusses the functionality of the DP8473 data 
separator blocks, after a brief introduction to floppy disk 
data separator theory. It then delves into the detail of PLL 
design theory, providing design equations and considera- 
tions that enables the user to optimize the performance of 
the PLL for various applications. 


2.0 THE FUNCTION OF A DATA SEPARATOR 


2.1 Encoding Techniques 


The floppy disk controller writes data to the floppy disk drive 
in a bit serial fashion as a series of encoded pulses. These 
pulses are then converted by the drive into magnetic flux 
reversals on the floppy disk media. The pulses can be later 
read by the drive and converted back to encoded pulses 
which can be decoded by the controller into the original 
data. 


Since data is one serial set of bits, and because “real 
world” imperfections in the writing/reading process can 
cause the serial information to vary and jitter, the clocking 
information is embedded into the data stream, which en- 
ables synchronization to the data by the circuitry in charge 
of reading the data. 


It is the purpose of the Data Separator circuit to take the 
encoded data from the disk, and to recover and separate 
out the clock signal. The separated clock and data signals 
are then sent to the controller's deserializer which converts 
the data to bytes of data suitable for microprocessor manip- 
ulation. 


The two most popular encoding schemes used on floppy 
disks are: FM (Frequency Modulation), and MFM (Modified 
Frequency Modulation). FM defines a bit cell for each bit of 
data. Each cell contains a position for a clock pulse and a 
position for a data pulse. Each of these positions are re- 
ferred to as windows. The clock pulse is present in every 
cell and a data pulse is present only if the data bit for that 
cell is a one. When this data is read back from a disk, a read 
clock can be generated from the clock pulses of the signal. 
An example of FM encoded data is shown in Figure 7. 


FM encoding was the first method used for recording data 
on a floppy disk. It is still used in some low cost systems 
where storage capacity is not a critical issue. This method 
works very well and requires relatively simple circuitry to 
separate the clock pulses from the data pulses when the 
data is read back. However, only 50% of the useful disk 
space is used for recording data. The other 50% is used to 
record clock pulses. 
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FIGURE 1. Examples of how clock and data information is encoded into 
FM and MFM formats. Notice the increased density of MFM over FM. 


MFM encoding allows 100% of the useful disk space for 
storing data, and is currently the most widely used recording 
format used for floppy disks. MFM defines a bit cell for each 
bit of data, similar to FM. Again, each cell contains a posi- 
tion for a clock pulse (clock window) and a position for a 
data pulse (data window). A data pulse is present if the data 
bit is a one. A clock pulse is present only if the data bit is a 
zero and the data bit in the previous bit window was a zero. 


A comparison of FM and MFM can be seen in Figure 7. 
Because MFM requires fewer pulses to encode the same 
amount of data, the information can be stored in half the 
area required for FM encoded data. The only drawback of 
MFM is that it requires better read/write head and accom- 
panying electronics. It also requires a higher precision data 
separator than FM requires. This is to resolve the location of 
each pulse more precisely than with FM. 


2.2 Typical Floppy Format 


A disk consists of many separate tracks. These tracks a are 
configured as a set of concentric circles. Each track con- 
tains a set of many sectors. Each sector contains one Ad- 
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dress Field and one Data Field. Figure 2 shows the most 
common track format used on floppy disks today. It is the 
IBM double density standard. 


The Address Field within a sector is used to identify what 
sector the following data field belongs to. It begins with a 
synchronization field or preamble to allow the data separa- 
tor (which will be described soon) to synchronize to the 
speed at which the data is being read from the disk. 


Next an address mark uniquely identifies this field as an 
Address Field. The address marks are encoded with a 
unique illegal pattern that is an MFM encoding rule violation. 
The violation is a missing clock pulse from a particular loca- 
tion within the byte. This illegal pattern guarantees that this 
is an address mark field and not a data pattern from some 
other area of the disk. The following four bytes identify the 
sector being read. This is followed by a CRC (Cyclic Redun- 
dancy Check). The CRC allows the controller to verify that 
the information read is free of errors. This is followed by a 
gap which is simply a series of bytes that physically sepa- 
rates the Address Field from the Data Field. 
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FIGURE 2. Typical format of a floppy disk. This is the IBM MFM standard. 


Notes: 


C2* = Data Pattern of C2, Clock Pattern of 14 
A1* = Data Pattern of A1, Clock Pattern of 0A 
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The Data Field contains the data that the sector represents. 
It begins with a preamble and data field address mark, simi- 
lar to the beginning of the Address Field. The actual sector 
data follows this. The data is followed by a CRC and then a 
gap, that separates this sector from the next. 


2.3 Obstacles in Reading Data 


Since MFM is the most popular floppy disk data encoding 
method the following discussion will refer specifically to 
MFM. 


The floppy controller must be able to decode the data read 
from a disk drive. Theoretically, this could be a fairly easy 
process. The controller must first synchronize to the clock 
pulses in the preamble field of a sector. After that, it is just a 
matter of checking when the next encoded data pulse ar- 
rives. The pulse can arrive, 1, 1.5 or 2 bit periods later. 
Using this information the controller can decode this and all 
subsequent bits, reconstructing the original data from this 
information. 


Unfortunately, this simple method is not so simple. The data 
pulses read back from a disk drive will generally be some- 
what different from the data originally written. 


There. are three major sources of data degradation. 


1. Bit Shift—As data is written, magnetic interaction of adja- 


cent bits cause the data to be shifted in time from its 
nominal position. When these flux transitions are record- 
ed close to each other, the superposition of their magnet- 
ic fields tends to move their apparent position. Thus when 
they are read, the floppy drive’s peak detector moves the 
peak of these flux transitions apart from each other. This 
is the major cause of instantaneous bit shift. 


(This type of data degradation is mostly predictable and 
can be partially compensated for by shifting the data as it 
is written to the disk in the opposite direction that the bit 
is predicted to shift. This is called Write Precompensa- 
tion. The DP8473 contains circuitry required to perform 
this function. The write precompensation circuit inter- 
cepts the serial data being written to the disk and shifts 
the data early, late, or none, based on the data pattern.) 


Several other factors can contribute to jitter. The drive’s 
peak detector may be unbalanced, resulting in a bit shift 
similar to that described above. This could cause positive 
going peaks to appear earlier than negative going peaks 
or vice-versa. Also, a long cable between the disk drive 
and the disk controller may contribute to bit shift. 


2. Motor Speed Variation (MSV)—This is an error in the 
spindle motor speed from the nominal, and causes the 
data rate to vary typically 1-2% for each drive. For de- 
sign purposes this value is doubled since drive media is 
interchangeable. Thus a slow drive can record data that 
is read on a fast drive. ' 


3. Instantaneous Speed Variation (ISV)—This is an addi- 
tional speed error that is a constantly changing affect due 
to disk-jacket friction, and mechanical resonances. Usu- 
ally this variation has a frequency component less than 
1 kHz and causes the data rate to vary an additional 1- 
2% (again doubled). 

While bit shift is the primary cause of decoding problems, 

the speed variations create difficulty in locking to the fre- 

quency of the data stream, and degrade jitter tolerance. The 
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data separator must be able to synthesize the average fre- 
quency of the data coming in, and if the disk data rate dif- 
fers from the nominal value then synchronization is more 
difficult. 


2.4 Performance Measures of a Data Separator 


There are several measures of data separator performance. 
The most universal one is window margin. Window margin 
measurements themselves can be subdivided into two cate- 
gories, Dynamic, and Static (described shortly). Window 
margin is defined as the amount of bit shift that can be 
tolerated by a data separator without mis-decoding the data. 
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FIGURE 3. Window Margin Timing Definition 


Figure 3 shows a timing diagram of a typical bit cell, and its 
composite data and clock windows. Theoretically a pulse 
(either clock or data) could be shifted in time either early or 
late relative to its nominal position by up to 1/, of a bit period 
and still be decoded correctly. This is the theoretical window 
boundary region in Figure 3. lf the pulse is shifted more than 
this, then it would fall into another pulse’s window. In reality, 
due to the limitations of practical data separator implemen- 
tations, the actual window boundary ‘in which data will be 
directly decoded is less than the full 14 period. This is 
shown in Figure 3 as the actual window region. Typically this 
actual window size is measured as either a percentage of 
the theoretical maximum or in terms of nanoseconds. The 
former is the more popular method and will be used here as 
well. In equation form: 


(Actual Window Size) 
(Nominal Theoretical Window Size) 


Window margin should be measured with a specified 
amount of ISV and MSV, at a specific data rate, with a spec- 
ified data field and format pattern, and a known bit shift 
algorithm. If any of these are unspecified, then a true com- 
parison of data separator performance is more difficult. Win- 
dow margin is usually specified as a percentage of the nomi- 
nal frequency window (as opposed to the nominal frequency 
plus the MSV). 


WM% = xX 100% 


There are two basic types of window margin tests. One test 
is where the data separator and controller must read a sec- 
tor of data, in which all the bits are shifted until the data 
separator cannot read the sector correctly. This is called 
dynamic window margin. A second test is to present a long 
sequence of perfectly centered MFM clock pulses except 
for one bit. This bit is shifted until an error occurs. This sec- 
ond test is called static window margin. 


Do Not Confuse the Two Measurements. The first one more 
correctly reflects the ‘Real World”. The second one is an 
indicator of the accuracy of the circuits that compose the 
PLL, but does not include most of the errors due to the 
response of the PLL. 


As an example of a dynamic window margin test: A data 
separator has a 70% window margin at 500 Kb/s, with a 
total + 1.5% MSV, and +1% ISV. The encoding is MFM, 
and the data pattern is a repeating DB6DB6 .. . (HEX) pat- 
tern. A reverse write precompensation algorithm is used for 
pattern dependent bit jitter (all bits are jittered). These con- 
ditions are one of the worst case conditions for analog data 
separators. This means that the data separator will correctly 
decode a pulse so long as it is shifted no more than 
+350 ns from its nominal position (the theoretical window 
at 500 Kb/s is +500 ns) over the full MSV and ISV range. 


Another data separator performance measurement is Bit Er- 
ror Rate (BER). This is a measure that is defined as ratio of 
the number of bit errors during long term reading divided by 
the total number of bits read. A small bit error rate is desir- 
able. BER is better for evaluation of total system perform- 
ance, since the performance of the whole system effects on 
this figure. Thus as a final system checkout the manufactur- 
er can specify the media, drives, data separator, and deter- 
mine the error rate of this system. It is relatively difficult to 
isolate the bit errors due solely to the data separator. This 
specification is a less exact performance measurement than 
window margin for a data separator. 


Why is Window Margin Important? 


The greater the window margin the lower the error rate. For 
example if a bit is read with too much bit jitter for the data 
separator, then that data cannot be read and the whole sec- 
tor (or file) is lost. This is especially fatal since floppies do 
not have error correction capability. 


Another area where window margin is important, is manu- 
facturing yields. A larger window margin ensures that when 
intermixing best/worst case drives and controllers there is 
minimum fallout. Thus larger volume vendors tend to try to 
optimize window margin to improve yields as well as data 
integrity. 

Each designer needs to decide for himself what margin re- 
quirements are necessary. In general, many high quality an- 
alog designs typically achieve 60-65% window margin un- 
der worst case conditions, with the best designs approach- 
ing 70%. 


5-31 


Later in sections 4.2 and 5.1 theoretical calculation and 
practical measurements of window margin are described. 


2.5 Analog Data Separator Basics 


The job of a data separator is to produce a read clock that 
follows the slow data rate change caused by the drive motor 
variation (MSV and ISV), but not track the instantaneous bit 
jitter. This read clock then is used to clock in the serial data 
into some type of deserializer. Generating a read clock for 
MFM encoded data is potentially difficult. Because of the 
MFM encoding rules, many clock pulses are missing from 
clock or data windows. As a matter of fact, in a long string of 
one’s, there are no clock pulses at all. A data separator 
must use both clock pulses and data pulses to synchronize 
to the encoded signal. The most popular method to do this 
is with a Phase Locked Loop (PLL). 


A PLL consists of three main components, a phase detec- 
tor, a filter, and a voltage controlled oscillator (VCO), as 
shown in Figure 4. Also in most cases a divider is used to 
divide the VCO frequency as needed. The basic operation 
of a PLL is fairly straight-forward. The phase detector de- 
tects the difference between the phase of the VCO (or divid- 
er) output and the phase of a periodic input signal. This 
phase difference is converted to a current which either 
charges or discharges a filter. The resulting filter voltage 
changes the frequency of the VCO (and also the divider) 
output in an attempt to,reduce the phase difference be- 
tween the two phase detector input signals. A PLL is 
“locked” when the frequency of the two phase detector in- 
put signals is the same. 
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FIGURE 4. Simplified Block Diagram 
of Phase Locked Loop 


With a slight modified version of the basic PLL, an MFM 
data separator can be made. A modification is required be- 
cause MFM encoded data is not a periodic signal. A phase 
comparison can only be made when a pulse arrives from the 
disk. When there is no clock or data pulse, the PLL should 
continue generating the frequency it was generating before 
the missing pulse. This is called a phase only comparison, 
and it is the usual method of tracking an MFM signal. 
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FIGURE 5. Simplified Block Diagram of Typical Data Separator 


A typical data separator is shown in Figure 5. |In addition to 
the components of a typical PLL, it includes a quarter period 
delay line and either a pulse gate or pulse inserter (not 
both). Both of these blocks enable the pulse gate or pulse 
inserter to decide when the phase comparison should be 
made. The quarter period delay line delays the incoming 
data pulses a quarter of a bit cell, and this feeds the pulse 
gate or pulse inserter. The pulse gate will disable phase 
comparisons when a VCO pulse occurs but read data puls- 
es are missing. The pulse inserter will insert fake read data 
pulses into the phase detector when there is a VCO pulse 
but no read data pulse. These components are required to 
determine the proper timing of the phase comparisons for 
MFM encoded data. The need for these blocks can be dem- 
onstrated by referring to Figure 6. Only the use of the pulse 
gate is described since this is what is implemented in the 
DP8473 data separator. 


Figure 6a shows two MFM bit cells, each with a clock pulse. 
The VCO output provides two clocks per cell since an MFM 
pulse can appear in either of the two windows that compose 
the bit cell. (Note for simplicity the divider block is ignored.) 
To achieve lock, the data separator tries to line up the rising 
edge of the input pulses with the rising edges of the VCO 
output cycles. MFM encoded data is not periodic, that is 
some of the cells are missing pulses. The data separator 
must decide when to make a valid phase comparison. This 
can be seen from Figure 6a where the phase detector first 
makes a comparison to an early pulse, which is correct, but 
then on the next VCO cycle the phase detector now com- 
pares this VCO edge even though no input pulses are pres- 
ent. Hence, there must be a mechanism for fooling the 
phase detector into not making a comparison. The method 
chosen in the DP8473 is to use a pulse gate to eliminate the 
unwanted VCO edge. 


However, disabling the phase detector’s input does not 
completely solve the problem, as shown in Figure 6b. Here 
the first early pulse is compared correctly. At the beginning 
the next VCO cycle the data separator does not know 
whether to do a phase comparison, since it does not know 
whether the pulse is missing or just late. Thus by the time 
the next pulse does arrive the PLL is lost. 


5-32 


Therefore, the DP8473 data separator uses a 1/, period (14 
bit window) long delay line with the pulse gate. Now with this 
delay line, all phase comparisons are made to the delayed 
data. Thus the PLL is operating 1/, of a period behind the 
data coming from the disk, but this allows the phase com- 
parison enable logic to determine whether a pulse will occur 
in a bit cell or not, and make the proper comparison. 


Figure 6c shows how this works. For an early bit, the data 
input enables a phase comparison, and the phase detector 
compares the delayed data bit to the VCO edge. In the case 
of this early bit, the proper pump up is generated. On the 
next VCO cycle, the quarter period delay has detected no 
pulse, and so no comparison is made. For the late bit, the 
comparison is enabled prior to the VCO clock, so a pump 
down is generated until the delayed data bit is seen by the 
phase detector. 


At nominal frequency, a delay of 1/4 of a bit ensures that the 
phase detector will be properly enabled even if the data bit 
is late all the way to the edge of its clock or data window. 
(Remember one bit cell contains a clock and a data window. 
A data pulse will appear within either (but not both) of these 
windows. Therefore the theoretical maximum amount of bit 
shift is 1/, of a bit cell.) 


The quarter period delay line solves this problem of fore- 
casting the future. It causes the MFM encoded data pulses 
to be delayed by a quarter of a bit period. This allows the 
pulse gate to determine when data pulses exist ahead of 
time and thus enable the phase detector only at the appro- 
priate times. 

It is important that the quarter period delay line be accurate. 
lf the quarter period delay line is not accurate (ie. it’s too 
long or too short), then the window margin performance of 
the data separator will be reduced. This performance reduc- 
tion is due to the PLL’s inability to correctly resolve bit shift 
near the edge of a bit window. For example, if at 500 Kb/s 
the delay line were shorter than it should be, say 400 ns 
long instead of 500 ns, then a bit shifted 450 ns from its 
nominal position is incorrectly decoded. The window margin 
in this case is immediately reduced 20% from it’s ideal. The 
same degradation occurs when the delay line is too long. 
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FIGURE 6. This shows why 2 1, period delay line is needed. 
a) Shows phase comparisons that occur if only a phase 
detector is used; b) Shows the data separator’s need to predict 
the arrival of a pulse; and c) Shows how the 1/, period delay fixes this. 
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2.6 Operation of an Analog Data Separator 


A data separator can be described as operating in one of 
three phases during each read cycle: Idle Phase, Initial 
Locking Phase, and the Tracking Phase. 


Initially, when the data separator is not being used to read 
data from the disk, it is in the Idle Phase. While in the Idle 
Phase, the PLL is both phase and frequency locked to a 
reference frequency. (Frequency comparison is implement- 
ed by forcing a phase comparison every VCO clock.) The 
PLL must eventually lock to both clock and data pulses of 
the encoded data when it is read from the disk, so the refer- 
ence frequency is generally two times the data rate frequen- 
cy. 

When data is to be read from the disk, the PLL switches 
from the reference frequency to the incoming data stream. 
Because the encoded data read from the disk is not a peri- 
odic signal, only phase comparisons are made. Since the 
PLL was initially locked to a frequency very close to twice 
the actual data rate, the time required for the PLL to lock 
onto the data read from the disk is minimized. 


To further minimize this locking time, the beginning of each 
Address Field and Data Field starts with a preamble (or syn- 
chronization field). The preamble is a series of bytes with a 
zero data pattern (all clock pulses and no data pulses). 
When read, the preamble will produce a periodic signal with 
little bit jitter. The data separator can lock to this signal with 
the least chance of an error. It would be ideal for the floppy 
controller to switch the data separator from the Idle Phase 
to the Initial Locking Phase at the beginning of a preamble 
to enable the maximum amount of lock time. 


Once the PLL is locked to the average frequency of the data 
being read from the disk, it should simply track the data 
frequency. This means tracking the slow data rate speed 
variations caused by the drive motor, yet ignoring instanta- 
neous bit jitter. This is the Tracking Phase. The data separa- 
tor then allows the controller’s deserializer to start decoding 
the incoming data. 


2.7 Digital Data Separators 


A second method of separating clock and data information 
is to use a digital data separator. While the circuits for the 
analog solution has evolved significantly, digital data sepa- 
rators have also improved somewhat, in a (less than suc- 
cessful) attempt to match the performance of the analog 
approach. .These circuits are described below. 


First Generation Digital Data Separator (DDS)—This circuit 
is a very convenient all digital data separator. Its primary 
advantages are simplicity, and low external parts count. This 
circuit usually consists of a set of counter timing circuits and 
some control logic to count times between individual pulses, 
and thus determine whether a pulse is clock or data. The 
SMC9216 is representative of this technology. Its major dis- 
advantage is performance, and the inability to optimize the 
window margin for various lock ranges. The dynamic win- 
dow margin for these types of circuits is usually around 55% 
with no MSV and as low as 30% with a +3% total MSV. 


Second Generation DDS—A sophisticated digital data sep- 
arator can be compared functionally to an analog data sep- 
arator. The ideal digital separator consists of a sampler 
(phase detector), a ROM look up table, with memory (filter), 
and a programmable counter (VCO). The pulse gate can be 
implemented as an extension of the ROM look up table. 
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These circuits are typically much better than 1st generation 
circuits, but still far short of the analog approach. These 
circuits have dynamic window margins of 50-55% over a 
+6% lock range (total MSV variation). 


3.0 DP8473 DATA SEPARATOR FUNCTIONAL 
DESCRIPTION 


The integrated floppy disk data separator from National 
Semiconductor combine the performance of an analog PLL 
and the ease of use of a digital data separator. It does not 
require any external trimmed components, and it has a data 
rate range from 125 Kbits/sec up through 1.0 Mbits/sec. It 
is built using CMOS technology to achieve good linear per- 
formance as well as low power operation. A block diagram 
for the data separator is shown in Figure 7. 


3.1 Block Diagram Description 


The heart of the DP8473 data separator is the main PLL. 
The main PLL consists of the VCO, programmable divider, 
phase detector, and the charge pump. The entire operation 
of the PLL and data separator logic is based on the Refer- 
ence Clock which should be an accurate reference frequen- 
cy. The Reference Clock is divided by two, then feeds the 
Secondary PLL, and the divide-by-N counter. As discussed 
later the Secondary PLL is used to calibrate the operation of 
the quarter period delay and Primary VCO. The Reference 

Clock’s Divide-By-N counter and the Programmabie Divider 

are both programmable counters whose divide by factor is 

determined by the data rate selected. The output of the di- 

vide-by-N and the Programmable divider is always twice the 

data rate. The output of the divide-by-N is used as a refer- 
ence frequency for the PLL to lock to when the PLL is idle. 

The output of the Programmable Divider is the separated 

clock that is used to strobe the incoming pulses into the 

controller’s deserializer. 

Note: Throughout this discussion, the Reference Clock as shown in Figure 7 
is the master clock for the data separator block. This Reference Clock 
also generates several other clock frequencies that are used by the 
data separator sub-sections. In the following discussions the term 
Reference Clock refers only to the signal in Figure 7 that feeds the 
divide-by-2 and divide-by-N blocks. Also the term Divide-By-N counter 
is used for the counter driven by the Reference Clock, whereas the 
Programmable Divider refers to the counter driven by the VCO. 

In the DP8473, the Reference Clock of Figure 7 is derived 
from a prescaler circuit that is operating at 24 MHz. The 
output of this prescaler circuit is 8 MHz for all data rates 
except 300 Kb/s. At 300 Kb/s the equivalent prescaler out- 
put is 9.6 MHz. The 24 MHz is intended to be a fixed fre- 
quency, but could be scaled lower for unique applications if 
desired. 


Under normal operation the Secondary PLL and the Primary 
VCO run at one half the Reference Clock frequency. Thus 
the Primary VCO’s output is 4 MHz (except at 300 Kb/s 
where the VCO output is 4.8 MHz.) Operation at different 
data rates is accomplished by changing the Divide-By-N and 
Programmable Divider. 


The basic operation of the Phase Locked Loop is fairly stan- 


dard although there are several added features in the 
DP8473 PLL. The phase detector determines the phase 
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FIGURE 7. A more detailed Block Diagram of the DP8473 data separator, a) showing the zero phase start up, secondary 
PLL, control logic block and external R’s and C’s. b) Also showing a more detailed diagram of the secondary PLL, main 


VCO and delay line. This highlights the self calibration technique. 
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difference between two inputs. One input is always the di- 
vided output of the Programmable Divider. ; 


The other input is either a reference frequency (derived from 
the Reference Clock) of twice the data rate while the data 
separator is in the idle mode, or when reading the disk the 
encoded data from the drive after it has passed through the 
quarter-period delay line. 


While in the idle mode, the phase detector determines both 
phase and frequency information. This is accomplished by 
forcing the pulse gate to enable all phase comparisions. 
This state is set by the top two multiplexers of Figure 7 
which in idle mode select clocks generated by the Refer- 
ence Clock to enable the pulse gate on every clock edge 
(hence all clocks are compared by the phase detector). By 
locking to the Reference Clock generated frequencies in 
both phase and frequency, the PLL is preventing from lock- 
ing back to a harmonic of this frequency. 


When the data separator is told to read the incoming data 
pulses, Read Gate is asserted. This changes the signals 
selected by the multiplexers. The top multiplexer switches 
to inputting the “raw” read data pulses into the pulse gate, 
and the bottom multiplexer sends read data delayed by a 
quarter bit period to the phase detector input. When this 
switch occurs, the Zero Phase Start-Up logic synchronizes 
the Programmable Divider’s output to be in phase with the 
very next arriving data pulse. This causes the PLL to acquire 
lock to the data quicker since it is starting with a “near zero” 
phase error between the Programmable Divider and the en- 
coded data. 


The quarter-period delay line consists of a series of voltage 
controlled delay elements. The encoded data from the disk 
drive enters the beginning of the delay line. The output is 
derived from the output of one of the delay elements. The 
delay element used for the output depends upon the data 
rate used. 


When locked to either the read data pulses or the refer- 
ence, the phase detector issues either a pump up signal or 
a pump down signal depending upon whether the VCO 
should increase or decrease its frequency. The length of 
this pump signal is proportional to the amount of phase dif- 
ference between the two input signals. When locked, the 
phase difference between the VCO and the delayed data 
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will be small. In this case the width of the pump signal could 
be so small that the rise time may prevent the signal from 
ever being recognized by the charge pump. To ensure that 
the charge pump can recognize even the smallest pump 
signal, both pump up and pump down signals are asserted 
at each phase comparison and the appropriate signal is ex- 
tended by an amount proportional to the phase difference 
between the two input signals. The pump signals are then 
subtracted from each other by the charge pump. Therefore, 
the rise time of the pump up or down signals will not de- 
grade the performance of the charge pump. 


The charge pump simply adds or removes an amount of 
charge proportional to the length of the pump signal to or 
from an external filter. The voltage of the external filter de- 
termines the frequency produced by the VCO. 


Finally a synchronized clock and serial data signal is sent to 
the controller's deserializer by the Data Synch Logic Block. 
This circuit takes the output of the Programmable Divider 
and the Read Data pulses, and synchronizes these two sig- 
nals, by centering the read data pulse in the appropriate 
Programmable Divider’s clock cycle. This allows the control- 
ler to easily deserialize and decode the data pulses proper- 
ly. 

An additional block not shown here, but used on the 
DP8473 is the filter selection logic. This logic is used to 
select different filters for different data rates. The descrip- 
tion and use of this circuitry is described in section 5.3. 


3.2 Self Calibration 


Normally, most VCO implementations would need an exter- 
nal precision capacitor (maybe trimmed) to set its center 
frequency. Also, the quarter period delay line would require 
an external trimming resistor to set the delay to exactly a 
quarter of the data rate. The actual delay of the delay ele- 
ments used in these functions would normally vary from one 
part to another due to normal process variations. However, 
the DP8473 has been designed to eliminate the need for 
these external trims. There are actually two PLLs in the 
DP8473; the Primary PLL, and a Secondary PLL. The Pri- 
mary PLL is used for data separation. The Secondary PLL is 
used to calibrate all of the delay elements used in the chip. 
This includes the quarter-period delay line and the main 
VCO. 


The VCO of the Secondary PLL is a ring oscillator of delay 
elements. The amount of delay that each inverter produces 
is regulated by a control voltage which is the internally con- 
nected output of the Secondary PLL. The Secondary PLL is 
locked to the same frequency as the Primary VCO, half of 
the reference clock frequency. The delay elements used in 
the secondary VCO are identical to those used in the Pri- 
mary VCO and are regulated by the same control voltage. 
There are also the same number of delay elements in each. 
Therefore, the center frequency of the Primary VCO is inter- 
nally trimmed to exactly half of the reference frequency. 
Since the delay elements in the Secondary PLL have a 
known delay, any number of identical elements that are set 
by the calibration voltage will have a very accurate delay. 
Thus the quarter period delay line is just a chain of these 
delay elements that have the desired total length. 


The delay elements used in the quarter-period delay line are 
also of the same type used in the secondary VCO. Because 
the delay of each element is accurately set by the Second- 
ary PLL, there is no need for any trimmed tuning compo- 
nents for any of these circuits. Essentially, the only external 
passive components required for the DP8473 are for the 
filter(s) (two capacitors and a resistor per data rate), and a 
resistor to set the gain of the charge pump (ie. the amount 
of charge pump current). 


3.3 Data Separator Read Algorithm 


Since the DP8473 floppy disk controller incorporates the 
analog data separator, it takes advantage of close proximity 
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of the controller and data separator blocks to implement a 
read algorithm that is much more sophisticated than previ- 
ous floppy controller integrated circuits. 


Before describing the details of the algorithm, a brief discus- 
sion of a disk read (or write) is necessary. When the control- 
ler is issued a read (or write) command, it is asked for a 
specified sector. The controller starts to look at the incom- 
ing MFM information. It scans this information, trying to lo- 
cate the proper address field. In order to do this, the data 
separator is first told to lock to the disk data, and once 
locked the controller looks at the incoming information. In 
most controllers, the data separator is told to look at the 
data continuously until the correct sector address is found. 
This makes the data separator susceptible to being thrown 
out of lock, since the controller is not “watching” the data 
separator to see if it has maintained lock through the search 
process (which it can easily lose). Once the correct address 
is found the controller must then ensure that the associated 
data area is read, by re-locking to the incoming signal and 
then reading (or writing) the data. 


Figure 8 shows in state diagram form the algorithm used by 
the DP8473 controller to ensure that disk data is correctly 
read (or written). This algorithm is much more sophisticated 
than previous generation controllers. The following de- 
scribes the operation. When the controller is idle, the data 
separator is locked to the crystal/clock reference in a fre- 
quency comparison mode. (Frequency comparisons are 
made by disabling the pulse gate, and ensuring that all ref- 
erence and VCO cycles are compared.) 
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FIGURE 8. State Diagram for a Data Separator Synchronization and Read Operation 
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When a read command is issued to the controller the con- 
troller asserts an internal Read Gate signal to the data sep- 
arator. This causes the PLL to switch from locking to the 
reference to locking to the data with the pulse gate enabled, 
and the primary VCO/divider started in phase with the next 
incoming pulse. The PLL waits 6-bit times to lock to the 
data. When the seventh bit arrives the data separator as- 
sumes that this bit is a preamble bit (thus an MFM clock bit). 
The controller/data separator then continues looking at the 
data until a non-preamble pattern is detected (ie. an MFM 
data pulse). It then checks to see if it has now encountered 
an address mark with the proper rule violation. If it has not, 
read gate is deasserted. The data separator returns to the 
idle state for 6 byte times, and then starts all over again. 


If three address mark bytes are found then the data separa- 
tor remains locked to the data while the controller looks to 
see if it has found the right address field. If the controller 
discovers that this field is not the correct address field then 
it deasserts read gate for 6 bytes, and tries again. 


If the correct address field is encountered, the controller de- 
asserts read gate during the gap between the address and 
data fields. It then re-asserts read gate, and follows the 
state diagram to read the data field (ie. looking for pream- 
ble, address marks etc.). 


This comparison is done on a bit-by-bit basis, therefore en- 
suring that the PLL never tries to lock on an unwanted field 
for more than one bit time. In other words, the PLL will never 
loose lock. This algorithm provides a very fast lock to the 
data stream, and ensures that the data separator never falls 
out of lock while reading the data. Both of these features 
reduce the need to do retries of operations to ensure cor- 
rect execution. 


4.0 DESIGNING WITH THE DP8473 
DATA SEPARATOR 


The following section is a fairly in-depth description of the 
design characteristics of the PLL in the DP8473 controller. 
(National Semiconductor cannot be responsible for the sani- 
ty of any one who ventures into this section. Hence we rec- 
ommend using the filter values supplied in the datasheets.) 


Two elements determine the overall performance of a 
Phase Locked Loop: the loop gain and the loop filter design. 
When using the DP8473 both of these elements are con- 
trolled by the user. The amount of current in the charge 
pump circuit can be set with an external resistor. This will 
set the overall gain of the PLL. The filter is external to the 
DP8473 and is user definable. This gives the user the possi- 
bility of tailoring the data separator performance to his own 
application requirements and design criteria. The following 
information will present some tradeoffs that apply in choos- 
ing the external components for typical applications. 


4.1 Basic Phase Lock Loop Theory 


This section will first start with the basic control systems 
model for a second order PLL, and then apply these basic 
equations to the individual blocks that compose the data 
separator in the DP8473 Controller. 


Initially Locked Model 


In order to understand the behavior of the data separator 
and to discuss the tradeoffs of the different design parame- 
ters, some background in the theory of PLLs will be present- 
ed. 
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Figure 9 shows a diagram of a PLL which is assumed to be 
in a locked state. Each box contains the phase transfer 
function of the corresponding block and each node has the 
relative phase signal. The PLL is locked, which means that 
the VCO output and the input signal are at the same fre- 
quency and in-phase with each other (the phase error is a 
constant). This model is useful for understanding the phase 
locking process when the PLL is switched from the refer- 
ence frequency to the incoming data. 


VF(s) 


TL/F/9419-11 
FIGURE 9. The Block Diagram for an Initially 
Locked PLL Control System, Showing the 
Transfer Functions for Each Block 


The frequency variations that this model take into account 
are assumed small enough so that the loop stays locked in 
frequency. Therefore, only the effect on the phase differ- 
ence is considered. Also, it is easier to refer to bit shift toler- 
ance in terms of phase. Hence the phase transfer functions 
yield the most appropriate information. 


The concept of phase is very much related with the concept 
of time. The advantage of phase information is that it is 
independent of frequency of the signal and it is measured 
as a pure number (radians). 


A simple RC filter model will be used to simplify the math. 
This is actually a good model because the effect of a sec- 
ond capacitor is only seen at high frequencies. This simplifi- 
cation allows the use of second order PLL theory that is 
easily available in literature. (See for example: R.E. Best, 
Phase Locked Loops, McGraw-Hill, 1984) 

From Figure 9 the closed loop phase transfer function for 
the loop can be derived using standard control system theo- 
ry techniques, and reduces to: 
2(s) _ _KoK'vooF (s)_ Py; 
64(s)_ S+KpK’vcoF(s) 

where K’'yco = Kyco/N, N being the number of VCO cy- 
cles between phase comparisons due to the divider that 
typically is inserted between the VCO and phase detector. 
The closed loop phase error function can be written as: 


H(s) = 


04 S+KpK’yvcoF(s) 2) 


Now we’ll evaluate the variables that appear in expressions 
(1) and (2). 


The Charge Pump 


In the phase detector/charge pump circuit a current is gen- 
erated in the correct direction (positive or negative) every 
time the edges of the VCO/divider output and the incoming 
data pulses are not coincident. The current is a pulse with 
amplitude equal to Ipump and length equal to the phase 
error between the two signals. The pump current is zero for 
the rest of the period, so the average current is: 


| 6 


where 6, is the phase error between the VCO/divider and 
input pulses. The phase detector and charge pump gain is: 


_ 'z _ lpump 
Kp 0. Om (4) 


where Ipywp = Kp X Ip. Ip is the current set by an external 
resistor at SETCUR pin. The current at this pin is: IR = 
Vrer/Ry, Kp = 2.5, and Vace = 1.2V. Thus combining 


equations: 
2.5)(1.2 
lpuwp = 2) (5) 
1 


Note that the maximum current that can flow to or from the 
charge pump is 500 yA, which corresponds to a resistor 
value of 3 kN. The minimum current is limited to 125 pA by 
Stability and leakage constraints on the internal reference 
circuits. So Ry must be smaller than 12 kf. In conclusion, 
the charge pump current and resistor can be set in the fol- 
lowing range: 


125 pA < Ipump < 500 pA 
3kN < Ry < 12k 


Any value in this range can be chosen, and usually the 
choice is dependent on the PLL filter Capacitor’s mechani- 
cal size and cost. We have chosen in the datasheet a value 
of 5.6 kM since it represents a good compromise of all 
these considerations. 


The VCO and Programmable Divider 


The VCO gain is defined as the ratio between a frequency 
change at the output vs. a voltage change at the input (FIL- 
TER pin). This value cannot be set by the user and has 
been designed to be immune to process, temperature and 
voltage variation. There is a variation of less than +20% 
between different parts, and the typical value of Kyco is: 


Mrad/sec 
Kvyco = aa (6) 
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The actual value K’yco for expressions (1) and (2) differs by 
a factor of N. N is the ratio between the frequency of the 
internal VCO and the “instantaneous” frequency of the 
data. This takes into account both the factor due to the way 
the data is encoded, and the factor due to the internal pro- 
grammable divider used for the data rate selection. The fol- 
lowing table gives the value of N for different codes, data 
rates, and data patterns. K’yco can be derived from these 
values of N. 


TABLE I. VCO Gain Reduction Factor for 
the DP8473 with a 24 MHz Crystal/Clock 


Data Patterns pow 
4 
8 


all 0’s, all 1’s 
010101... 

500 Kb/s MFM all 0’s, all 1’s 8 
010101... 16 


300 Kb/s MFM all 0’s, all 1’s 
010101... 
250 Kb/s MFM all 0’s, all 1’s 16 
010101... 32 
FM . 16 
8 


So for a 250 Kb/s MFM data rate N= 16 and K’vco = 1.56 
Mrad/set/volt. 


The loop filter calculation is made assuming lock and acqui- 
sition during a preamble (all 0’s pattern), so these values of 
N are used in the bandwidth and damping calculations 
shown later. 


The PLL Loop Filter 


Inside the data separator, the charge pump output is con- 
nected directly to the VCO input. A filter is attached exter- 
nally to this point. The typical configuration of this filter is 
shown in Figure 10. The output of the phase detector/ 
charge pump circuit is basically a current generator with a 
very high output impedance (hundreds Of kN). This high im- 
pedance combined with the external capacitor, Co, of the 
filter provide a small (close to 0) steady phase error after a 
frequency step in the input signal. The charge pump setting 
along with Co sets the bandwidth on the PLL. The DP8473’s 
charge pump circuit eliminates the need for an external ac- 
tive filter. The resistor Ro is the damping resistor and it con- 
trols the stability of the loop. 
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FIGURE 10. Simple Schematic of Typical 
DP8473 Data Separator Filter Configuration 


The filter design is usually improved by adding another ca- 
pacitor in parallel, C;. This second capacitor is intended to 
improve the low-pass filtering action of the PLL. In our sub- 
sequent filter discussions, C, is ignored initially since its val- 
ue will be much smaller than Co. 


In the DP8473, the input of the filter is a current from the 
phase detector/charge pump, the output is a voltage to the 
VCO. Therefore, the transfer function of the filter of Figure 9 
is simply its impedance: 

1+ sRoC 
poe ewe (7) 

sCo 

(As mentioned, we are ignoring the effect of C, for now.) 
Substituting these equations into (1) and (2) produces: 


K'vcoKp(sReCe + 1) 


- K’vcoK “) 
(s2 + s(K’ycoReKp) + vgoKo 
2 


This then reduces to a standard second order equation of 
the form: 


F(s) = Z(s) = 


H(s) = 


(2sfwn + wn?) 
(s2+ 2Lap8 + on?) 
and similarly the error function has the form: 

s2 

(2 + Blw.s + wr?) (9) 
(s2 + 2Lw78 + Wn?) 
in this discussion we won’t be making use of the error func- 
tion equation, however it is the basis of much of the acquisi- 
tion equations which are used to derive Figures 17 and 72. 
The complete analysis is beyond the scope of this paper, 
but is discussed in detail by most of the references. From 
equation 8, and the standard second order equation we can 
solve for the bandwidth, w, and damping, ¢. The natural 
frequency is: 


H(s) = 


H.(s) = 


5-40 


K’ycokK 
on? = Kvcoko 


ae ee [tpumeK'vco 
f — QarCo 


By combining Kyco and Ipump constants, the design equa- 
tions for the PLL can be simplified, by introducing Kp.L, 
which is defined as the product of Vaer X Kp X Kyco. By 
using the Kp constant the above equation becomes: 


KPLL 
= eememenennemenennent 1 
on Vv 2arNR1Co (11) 


where N is the VCO divider as defined in Table |. The damp- 
ing factor is given by: 


(10) 


; K’vcoR2KpC2 
2twn = K’yooR2Kp— 
2 
2C0n = @n2R2Co 
@rRoC 
t = ——— (12) 


These two parameters (equations 11 and 12) will allow us to 
calculate the PLL filter components based on bandwidth, 
and damping. The closed loop phase transfer function 
shows that the PLL behaves like a low-pass filter. It passes 
signals for input phase signals whose frequency spectrum is 
between 0 and wp. This means that a second-order PLL is 
able to track a phase and frequency modulation of the input 
signal up to a frequency equal to w,/2z7, and it will not 
follow input variations of higher frequencies. 


4.2 System Performance and Filter Design 


The system performance of a data separator can be de- 
scribed by three main criteria. 


1) Acquisition Time—ability to guarantee lock during a pre- 
amble. 


2) Window Margin—ability to recognize data shifted in time 
from its ideal position (bit jitter) without incorrectly decod- 
ing it. 

3) Tracking of Disk Data—ability to follow slow (<1 kHz) 
disk data speed variations. 


The filter design must meet the requirements set by these 
performance characteristics. The two conflicting require- 
ments are that the bandwidth must be large enough to en- 
sure proper locking to the data stream, but as small as pos- 
sible while tracking the data to maximize bit shift rejection 
and window margin. Primarily the filter sets the bandwidth, 
and it is determined by the required acquisition time as 
shown later. 


To illustrate this, a numerical example (for 500 Kb/s data 
rate) is presented following the design considerations step 
by step. After we have completed the paper design a dis- 
cussion of performace measurements is provided. Once the 
initially calculated paper values are chosen, then real mea- 
surements must be made, and adjustments to these values 
are decided upon. 


Acquisition to the Data Stream 


Acquisition means to achieve phase lock and to bring the 
phase error of the VCO to zero, or close to it. This includes 
acquisition of phase lock to either the data input or to the 
reference frequency. The lock mechanisms for these two 
cases may be different. 


At the moment just before Read Gate is asserted, it will be 
assumed that the VCO is locked to the reference frequency. 
It has been locked for a relatively long period of time, there- 
fore the phase error between the VCO output and the refer- 
ence frequency is nearly zero. Because the system is initial- 
ly locked, the initially locked model can be used. 


When Read Gate is asserted by the controller, the input to 
the phase detector is switched from the reference frequen- 
cy to the data stream. This is an instantaneous change of 
both phase and frequency to the input of the phase detec- 
tor. The loop must be designed to assure that it can achieve 
both phase and frequency lock to the incoming data. Phase 
and Frequency Lock implies that the steady state phase 
and frequency error at the phase detector input is near zero. 


The goal is to lock to the data stream within the length of 
the preamble, very often half of the preamble to increase 
the probability of locking successfully. In fact, during a pre- 
amble the data pulses are relatively free of bit shift and the 
frequency is constant. There are two basic requirements to 
ensure that the data separator correctly locks to the data 
stream in the required amount of time. 


1. The loop bandwidth must be large enough to ensure that 
phase and frequency error of the VCO goes to zero within 
the required time (usually within 14 the length of the pre- 
amble). This implies that the shorter the preamble the 
larger ap. 

2. The filter must also be designed to guarantee that a data 
pulse will never fall out of the data window during the lock 
process. The peak phase error during acquisition must be 
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less than 12 of a data or clock window (i.e. or < 7/2). If 
the filter is incorrectlly designed and the data pulse falls 
outside the window (called cycle slipping) during acquisi- 
tion, the loop may never lock within the desired acquisi- 
tion time and the encoded data will not be decoded cor- 
rectly. This requires that to guarantee lock over a wider 
variation of data rate, a larger wy is required. 


Both of these requirements can be approximately derived 
from Figures 17 and 72. These curves piot relative phase 
error normalized to wr, versus time in units normalized to 
@p. This period of time, and the amount of phase error pres- 
ent is dependent upon wp, and damping. 


For the first requirement, the phase error settles close to 0 
in about: 


5 


tacq = ae (13) 


This equation yields a minimum starting bandwidth, and is 
valid for systems where the speed variation of the incoming 
data is small (+1-2%). 

For the second requirement, the peak phase error, 
9e(PEEK), during acquisition can be determined from Figures 
17 and 72. The design must ensure that the sum of this 
peak phase error due to a phase step, 6e(PHASE), the peak 
phase error due to a frequency step, Ge(FREQ), and the 
phase error due to PLL noise and non-linearities, 6e(PLL) 
must all be less than 7/2. In equation form: 


9e(PEAK) = 9e(FREQ) + 9e(PHASE) 
vie 
+ Oe(PLL) < 3 (14) 


Thus the sum of the peak phase errors for a phase step and 
a frequency step must be calculated. 
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FIGURE 11. A Plot of Normalized Phase Error of a PLL to a Phase Step Input 
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Pulse Pattern 


TL/F/9419-15 


(a) 


Data Pattern 


Pulse Pattern 
TL/F/9419-16 


(b) 
FIGURE 13. Two “Worst Case” Data Field Patterns for Measurement of PLL 
Bit Shift Tolerance a) “11000” Pattern with 2/3 .s Pulse Spacing (at 500 Kb/s), and 
b) A “DB6” (“110”) Pattern with 2/4 ys Pulse Spacing (at 500 Kb/s) 
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For determining the peak phase step error, the value of 
9e(PHASE) is the maximum Y-axis value of the chosen curve 
multiplied by the input phase step, and the result is in radi- 
ans. For example with a damping of 0.7 a maximum error of 
—0.20 occurs at about 3 wp. If the maximum phase step is 
a/2 when switching to the data, then the peak phase error 
is 0.1 a radians. The choice of which curve to use depends 
on damping factor desired. 


Since a frequency step is also present at the transition of 
READ GATE, the peak phase error of the frequency step 
given by the normalized plot in Figure 12 must also be de- 
rived. The phase error can be calculated by reading the 
peak Y-axis value from the desired curve and using: 


Ao . 
Oe(FREQ) = Ln (15) 


to determine 9e(FREQ). Where Y is the value read from the Y 
axis, and Aw is the maximum frequency step times 27. The 
maximum frequency step is the worst case frequency varia- 
tion of the data being read from the disk drive, which is the 
sum of the MSV and the ISV. 


With the equations for loop bandwidth, damping factor, and 
the relationship between acquisition time and bandwidth, 
the following example demonstrates the first steps at arriv- 
ing at the loop filter components. . 


Example 1: Design a data separator using the DP8473. De- 
termine the loop bandwidth, dampening factor, 
and Co, Ry, Re component values for a data 
separator that decodes MFM data at a data 
rate of 500 kbits/sec. The preamble is 12 bytes 
long, and the total MSV/ISV is +6%. 


w,(t) 
FIGURE 14. A Plot of Normalized Bit Shift Resistance Versus Time for a PLL 
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Select a value of pump current resistor. For ex- 
ample 5.6 kQ. 


Find out the minimum acquisition time required. 
Generally, half preamble which is 6 bytes. Thus: 


tacq = ((6 X 8) bits) x 2 ps/bit = 96 us 
Next calculate w, based on the larger of the 


two acquisition requirements. The first require- 
ment for wp is: 5/@, < tacg: Thus: 


@n > 52.5 Krad/sec. 


Calculate w, for the second acquisition require- 
ment, i.e. ensuring the maximum phase error is 
less than 7/2. Due to the Zero Phase start-up 
block within the Data Separator, the maximum 
phase step when switching to the data is 7/8. 
We’ll choose a damping of 0.7. From Figure 717 
the maximum overshoot is 0.2 (7/8) = 0.08 
rad (Note 1.0 rad = 314 ns at 500 kb/s). As- 
sume that the data separator contributes a total 
0.1 rad noise error. This is for charge pump 
asymmetry, delay line variation, and VCO jitter. 


Using equation 18: 


Oe(PEAK) = 9e(FREQ) + 0.08 rad + 0.1 read < 
mw/2or... 


900 ns > 25 ns + 31 ns + 6eFREQ) which 


results in: 


9e(FREQ) < 443 ns or 1.41 rad 

This yields the maximum tolerable phase error 
due to a frequency step (which is dependent on 
Wp). 


C 
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First find the maximum frequency step in radi- 

ans that the data separator must undergo. The 

design requirement was 6%, but in order to ac- 

count for gain variations in the data separator 

some margin on top of this is required, so we 

will design to 8% total speed variation. Thus: 
Aw = 0.08 (500k) 277 = 251 Krad 

The relative phase step error from Figure 12 

using a damping factor of 0.7, is Y = 0.45, plug- 

ging into equation 15: 

__ 0.45 (251 Krad) 
1.41 

The larger of the two calculated w,’s is 80 

Krad/sec, so that is the chosen bandwidth. 


KPLL 
277RyNop2 
7 75 Mrad 
~ Qar(8)(5.6 kQ)(80 k2) 


We will round down to the next lowest standard 
value of 0.039 pF. 


= 80 Krad/s. 


C2 = (16) 


= 0.041 pF 


2¢ 
is 17 
Re wonCe (17) 
_ 2t 210.7) | 
~ Comp (0.039) (80K) — sae 


In the above example we have calculated a set of compo- 
nent values for the acceptable bandwidth based on acquisi- 
tion. This calculation yields a good starting point from which 
experimental measurements can be made, but may not be 
the optimum values. Depending on other considerations we 
may decide to chose a value of wp that is slightly different 
depending on window margin, or bit shift performance; as 
will be shown. 


Theoretical Dynamic Window Margin Determination 


Previously in section 2.4 Window Margin was discussed in 
terms of distortions of the data that degrade the window 
margin. Here, using a model for these distortions we will 
arrive at a calculation of the expected Dynamic Window 
Margin for the DP8473 analog PLL. The effects of Window 
error, VCO jitter, and PLL response to a previous or present 
bit shift all cause a reduction of the available window margin 
available. (Remember the goal is to maximize the total avail- 
able bit window.) The following analysis provides a feel for 
the amount of degradation due to various parameters, and 
serves to provide an indicator of the expected PLL perform- 
ance. The following is a list of parameters that cause loss of 
window: 


Internal Window Error (or static phase error): The win- 
dow error is related to the accuracy of the internal delay line 
in the data path before the phase detector. As explained 
previously, this delay line is automatically trimmed using the 
crystal frequency as reference. The static phase error is the 
sum of two factors. One of these factors is the difference 
between the data stream frequency and the nominal and 
unavoidable internal mismatches. Another contributing fac- 
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tor is charge pump leakage. This factor causes a perceived 
phase error that is equivalent to varying the delay line 
length. This is usually > 2%-4%. 


VCO Jitter: The VCO jitter is caused by the modulation of 
the VCO frequency with secondary VCO frequency, crystal 
oscillator and other noise. This can account for another 
2-5% percent of error. 


PLL Response: The PLL response to a data bit shifted from 
its nominal position because of noise or jitter is directly 
translated in a margin loss for the bits following any shifted 
bit. For a highly accurate PLL circuit this is the primary 
source of error, and it typically results in a window loss of up 
to 20%, depending on data pattern and frequency variation 
constraints. 


All of these degradations are summed into the Window Mar- 
gin specification. 

= (14 Bit Window) — ®e(PLL) — %e(SwL) (18) 
This yields the margin loss, where O@wm is the total window 
margin or the total amount of a half bit cell in which a data 
pulse will be properly recognized, pit) is the error due to 
PLL response, and 9esw1) is the total error contributed by 
imperfections of the PLL circuitry (including delay line accu- 
racy, leakage, and noise). 


The window margin loss contributed by the device accura- 
cies are relatively straightforward, and are supplied by Na- 
tional. The more difficult task is to determine the window 
margin loss due to the PLL response. 


Tracking of the Disk Data 


The bit shift produced by an average disk depends on the 
pattern of encoded pulses recorded on the media. Pulses 
that are placed close together appear to push each other 
apart when they are read back. This is the primary cause of 
bit shift. 


The PLL tolerance to bit shift is dependent on the amount of 
data bits that are shifted, and the data pattern. It can toler- 
ate more bit shift by individual bits if only a few of the bits 
within a pulse stream are shifted. However, if most of the 
data read by the PLL is shifted (both early and late), the loop 
is constantly correcting itself and is never really phase 
locked. Because it is not phase locked the maximum tolera- 
ble bit shift is less. 


Some data patterns are better at determining PLL perform- 
ance than others. These are patterns that are particularly 
difficult for a PLL remain locked to while the data pulses are 
shifted early and late. For example a bit pattern of “11000” 
is difficult to decode since it has pulses alternately spaced 
by 1 and 1.5 bit cells. See Figure 13a. This is difficult to 
decode in some cases because under maximum bit shift 
conditions all pulses are equally spaced. 


Another bit pattern that is difficult to decode is a repeated 
bit pattern triplet of “110” (or “101” also referred to as a 
“DB6” pattern), which has a pair of pulses one bit cell apart, 
and the next pair two bit cells apart. This pattern is particu- 
larly difficult to decode because it contains two pulses of 
minimum spacing, followed by two maximum spaced pulses. 
This pulse pattern is shown in Figure 19b. 

Unlike the acquisition process described earlier, the PLL 
must largely ignore individual bit shifts during the tracking 
phase. The PLL should only follow the longer term average 


data rate. The desired PLL response during the tracking 
phase is somewhat different from the response required 
during the acquisition phase. Instead of a high bandwidth to 
decrease the lock time, a low bandwidth is preferred to pre- 
vent the PLL from following individual bit shifts. When 
choosing the filter bandwidth, the lowest possible value 
should be used that still satisfies the acquisition time re- 
quirement. 


Figure 14 can be used to determine the theoretical window 
margin. This curve of phase bit shift resistance plots the 
amount of error introduced in the PLL’s VCO by a phase 
error. The following example will show the steps involved in 
calculating expected window margin, and illustrate some 
concepts of tracking data. 


Example 2: Determine the total dynamic window margin for 
a loop with a bandwidth of 90 Krad/sec, a 
damping of 0.7, and at a 500 Kb/s data rate. 
The intrinsic circuit errors amount to 0.1 radi- 
ans of the window. Calculate the margin for 
both the 110 and 11000 pattern. 


First step is to calculate the bandwidth of the 
PLL while tracking these data patterns. The 
bandwidth is the square root of the ratio of the 
pulses per bit cell relative to preamble data, 
multiplied by the bandwidth. Preamble data has 
1 pulse/bit ceil, and a 110 pattern has 2 pulses 
per 3 bit cells, while a 1100 pattern has 4 puls- 
es for every 5 cells. Thus: 


®n(110) = (90 Krad/sec) x v0.66 
= 72 Krad/sec 
®n(11000) = (90 Krad/sec) x 0.8 
= 81 Krad/sec 


To analyze the problem, we need to look at 
two bits. The present bit which has an early 
phase step, and the next bit which has an 
equal late phase step. We must determine how 
large a shift in the first bit can be tolerated 
such that the same amount of shift in the sec- 
ond bit will still fall within the proper window. In 
equation form: 

Be(2) + Kwa A9e 1) + OPLL = OT (19) 
where A@@1), the shift of the first bit, is multi- 
plied by Kwa, which is the affect the first bit 
has on the VCO when then next bit arrives. @7 
is the total window available (in this case +500 
ns). Opt is the static error degradation due to 
the DP847x and is 10% of 500 ns or 50 ns. 
A8@q2) is the maximum phase error of the sec- 
ond bit. We can solve for A@e(2) assuming that 
A8q1) = A9e(2): 


OT — OPLL 
A8e(2) = —— + Kwe (20) 
The value of Kywy is the value read off the y- 
axis of Figure 14, at a time normalized to wp. 


This time is the time between two bits or:: 


For a “110” pattern w,(t) = (4 ws) (72 Krad/s) 
= 0.29, resulting in a value from Figure 714 of 
Kwem = 0.37. And for a “11000” pattern w,(t) 
= (3 ws) (81 Krad/s) = 0.24, which results in 
Kwa = 0.28. Using 0.37, the window margin 
is: 
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500 ns — 31ns. 
—T37— 37 = 342 ns 


In terms of percentage this is 100*(342/500)% 
= 68%. Note that this is the window margin at 
nominal frequency. 


A8q2) = 


Open Loop Bode Plots and the Second Capacitor 


Figure 15 shows the open loop gain Bode plot for the sec- 
ond order PLL. This plot is useful as a double check to 
make sure that we have a stable design and is important to 
show the affect of the second capacitor in the filter. in this 
plot, it is assumed that the charge pump output impedance 
is infinity. 


Open 
Loop 
Gain 
(dBs) 


Frequency (radians/sec) 


TL/F/9419-18 
FIGURE 15. Bode Plot of Open Loop 
Gain of DP8472/3/4 Using a Typical 
Filter at 500 Kb/s (from Example 1) 


As can be seen, the gain starts off with a slope of 40 dB per 
decade due to the two poles of the filter and VCO. The 
phase angle starts at — 180°C. The stabilizing zero is intro- 
duced at w; = 1/ReaCo, and causes the slope to change to 
20 dB per decade. w,, is the extrapolation of 40 dB/dec line 
to 0 gain, and the actual crossing point is w = 2 £wy. Exam- 
ple 4 discusses how to plot this curve. 


The further reduce the effect of unwanted changes in the 
VCO phase the second capacitor can be added to the filter. 
This capacitor, Cj, introduces a pole, Figure 15, between 
the loop natural frequency and the data rate frequency. The 
pole due to the second capacitor occurs at wo = 1/To = 
1/RoC1. This capacitor provides further attenuation of bit 
shift caused frequency components, and the pump pulse 
noise, both of which have frequency components that are 
around the data frequency. The only considerations in 
choosing the value of this capacitor are related to the stabil- 
ity of the loop, and inadvertently affecting w,. A good criteri- 
on for stability is that the Bode plot of the open loop gain, 
Figure 15 must cross the O dB gain with a slope of 
20 dB/dec, ie. before the break caused by C,’s pole. 
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To determine a simple method for deriving C;, we must look 
at the open loop gain of the PLL along with the transfer 
function of the loop filter. The open loop gain is: 


82 _ KpK’vco 
6, ae F(s) (21) 
Where F(s) is the filters transfer function: 
( 1+ sfeCe 
= Fe) = XS SOL 
F(s) = Z(s) ( $F20iCe) (22) 
(Cy + Co) 


Combining these two equations and manipulating we find 
that the second pole occurs at: 


1 
wp = —— (confirming Figure 75) 
RoC, . 
This is assuming Co > > C, (which we ought to assume to 
maintain the validity of previous filter assumptions). 


The zero introduced by Cg and Ra should be designed to be 
close to the 0 dB gain crossing. Its frequency is wz = 
1/RoCo. The frequency of the pole due to Roe and C; is 
approximately wp = 1/RoC}3. This pole must not significant- 
ly change the slope around the 0 aB line. If we choose C; = 
C2/20 the effect on the slope of the transfer function is less 
than 1 dB/decade at the frequencies around the 0 dB gain 
line crossing. Thus as a guide: 


(23) 


c, <2 


20 “a 


Example 3: For example 1, determine C. 
Very simply for example 1a: 


< 0.039 WF 


C 
1 20 


= 2000 pF 


The 1/20 factor provides the approximate value 
for Cy. 


Example 4: Plot the Bode diagram of the open loop gain for 
the DP8472 with Cp = 0.027, C; = 1000 pF, 
~ Ry = 5.6 kD, Ro = 5450. 


There are two easy methods of doing this. One 
method involves determining the open loop 
gain at a low frequency, where the poles and 
zeros don’t have any affect, and then using this 
gain point at a start drawing the properly sloped 
lines to the break point frequencies. A second 
method is to calculate the wr, and 2fwp fre- 
quencies. 


5-46 


For the first method, first calculate the locations 
of 71 and 79 in Figure 75. Thus 


Be 1 1 
(SS 
T1 ReCo 
1 
= —_——______ = 6.8 X 104 
(5450)(0.027 pF) 
. T2 RoC; 
: = 1.8 x 106 


~ (5452)(1000 pF) 


Now pick a point that is below w 4, and calculate 
the open loop gain, which is: 


KycoKpVREF 1 
KLoop = 20 log ( onRiNw / \wCo 


At w = 104, the KLgop is: 


12 x 106 


———— | = 39 dB 
ane 


KLoop = 20 log ( 


Now draw a line from w = 104 to w, with a 
40 dB/decade slope. Then at w, draw a line to 
wo with a 20 dB/decade slope, and finally draw 
a line from w2 with a 40 dB/decade slope. 


To understand the affect of C;, the additional attenuation 
introduced can be determined as using: 


Ap(w) = (25) 


@ 
1+— 
Wp 
Using our previous example 1: 


1 


= —————__ = 1834 Krad, 
1000 pF 5459 eeene 


wp 


@ = 2a (500 kHz) = 3142 Krad/sec. 
Thus 


1 ‘ — 
3142 = 0.37 


1834 


Ap(w) = 


which yields an additional 9 dB of attenuation. 


Choosing Component Tolerances and Types 


One of the most often asked questions is how accurate 
should the filter and charge pump resistors and capacitors 
be? The answer depends on how accurate a data separator 
is required. For a good performance design, the following 
criteria can be followed for each component: 


Ry: The pump set resistor’s tolerance affects the loop band- 
width, w,. The loop bandwidth directly affects window mar- 
gin. Due to the square root relationship, a 5% change in this 
resistor changes wp, by 2.5% which in turn affects the win- 
dow margin by 1-2%. It is thus recommended that R; be a 
1% resistor. A standard carbon or metal film resistor with a 
low series inductance should be chosen. 


Ca: The main filter capacitor also affects w, in the same 
way as R; so it too should be relatively accurate. 5% is 
recommended. This capacitor should be a very good quality 
capacitor, with good high frequency response and low di- 
electric absorption. Mica is a good choice although maybe 
too expensive. Polypropalene and metal film are good as 
well. Avoid Mylar or Polystyrene. 


Ra: This resistor has a much lower affect on window margin, 
and thus standard 5% resistors can be used. 


C1: The second capacitor’s accuracy in not critical 10%- 
20%, but its high frequency characteristics should be quite 
good, similar to a good high frequency power supply decou- 
pling capacitor. 


5.0 ADVANCED TOPICS 


The following sections discuss several specialized areas of 
evaluation and design of the PLL for the DP8473 controller. 
Also a short discussion of the crystal oscillator design con- 
siderations is given. 


5.1 Design and Performance Testing 


Testing data separators can get rather complicated. Once 
the PLL circuitry, gain, bandwidth, and damping are set, 
then data separator lock range testing, window margin test- 
ing, and finaly bit error rate testing may be undertaken. This 
testing can require some fairly sophisticated setups, and is 
time consuming. To help the designer get started, a rigorous 
approach to floppy disk PLL design verification is described 
with reference to desired performance and available equip- 
ment. If the designer is not concerned about optimum per- 
formance for custom applications, then the values for the 
PLL filter and pump resistor provided in the DP8473 data- 
sheet should prove more than adequate. 


Step 1—Calculating the Filter/Pump Resistor: Following 
the examples above, the optimum “paper design’’ filter 
components should be calculated (or use the values provid- 
ed in the datasheets and tweak them). 


Step 2—Testing Lock Range and Damping: For charac- 
terization of the PLL’s acquisition, a fairly simple setup can 
be used, which utilizes a pulse generator to provide a pulse 
train that simulates a preamble to be input into the data 
separator’s read data input. A second synchronous square- 
wave that is 20-50 times the period of the data pulses is 
applied to read gate. The frequency of the read data pulses 
should be varied from the nominal data rate to the limits of 
the desired lock range, and the lock range requirement 


5-47 


should be verified by monitoring the Filter pin, and the Pump 
outputs. Figure 16 shows a typical setup, and some typical 
waveforms on the pump and filter pins during acquisition. 
Figure 16b shows a proper locking PLL which does not ex- 
hibit “cycle slipping”. Cycle slipping is denoted by the saw 
tooth waveform on the filter pin, which can be seen by the 
locking shown in Figure 16c. 


In both Figure 16b and c the total amplitude, AV, of the filter 
pin waveform is typically less than 200 mV. 


The object is to adjust the PLL bandwidth to ensure that 
when locking over the desired range of data rates (for ex- 
ample 500 Kb/s +6%) that no cycle slipping occurs. If slip- 
ping does occur then the bandwidth should be increased. 


A second piece of information that these curves provide is 
verification of the damping of the PLL. As in Figure 76b the 
filter pin waveform should slightly overshoot, and then (may- 
be) slightly undershoot the eventual locked voltage. If there 
is very little overshoot then the loop may be overdamped, 
and if the filter pin voltage “rings” for a few cycles the loop 
is probably underdamped. For example, Figure 16c not only 
cycle slips, but does not overshoot, therefore the loop band- 
width may be fine, and the loop is just too heavily damped. 


Step 3—Window Margin Evaluation: Usually to perform 
this test a disk simulator should be used to simulate the 
worst case drive read data conditions, and measure the er- 
ror performance of the data separator. This simulator can 
be used to vary the following parameters: 


1. Motor Speed Variation 
2. Instantaneous Speed Variation 


3. Instantaneous bit shift 
(to determine the window edge) 


4. Data pattern. 


The test setup shown in Figure 17 can accomplish some of 
this testing. The disk simulator looks like a formatted disk to 
the controller/data separator. To test the data separator, 
software in the host computer performs a repeated series of 
read operations over a period of time, while the designer 
programs the disk simulator to vary the data rate from one 
end of the lock range to the other. At each data rate the bit 
shift is increased until the error rate increases above a mini- 
mal threshold. 


This testing should measure window margin over the entire 
lock range, and under conditions as described in section 
2.4. Typically this process is a trial-and-error process. The 
bandwidth and damping can be adjusted based on the re- 
sults of these tests. 
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FIGURE 16. Simple PLL lock/performance testing; a) Typical frequency generation hardware to generate read gate and 
preamble for various frequencies. b) Using this hardware a typical lock acquisition showing key signals. This is a 
proper lock waveform. c) This shows an unreliable lock to a frequency beyond the lock range of the PLL. Cycle 
slipping occurs because the PLL is unable to respond quickly enough to the frequency step. 
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FLOPPY DISK DRIVE SIMULATOR DP8473 
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FIGURE 17. Block Diagram of Connection of Disk Simulator to Data Separator to be Tested 
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FIGURE 18. Various window margin graphs. a) Data separator with slightly long delay line and fairly normal lock range; 
b) data separator with short delay line; c) a relatively poor data separator with a long delay line, and wide bandwidth. 
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ISV may also be simulated. Unfortunately most disk simula- 
tors do not easily test for this. Therefore it is very likely that 
the window margin measurement will be made with only 
MSV variation initially. This may also be desirable since 
MSV-only testing will yield a better understanding of the 
PLL’s lock range. If MSV-only testing is done initially then 
the design of the PLL and total frequency range for evalua- 
tion should be the sum of the desired MSV and ISV. For 
example, a design requirement of +3% ISV and +3% MSV 
can be approximated by +6% MSV. 


If an MSV-only test is done, it may be useful to then follow 
this with a simple ISV test just to double check that the loop 
will follow the ISV properly with little degradation in window 
margin. It is also sometimes useful to vary the ISV frequen- 
cy until the window margin degrades, just to give an indica- 
tion of how high the ISV frequency can go. A typical PLL’s 
ISV performance should not degrade until the frequency is 
greater than about 800 Hz. 


Step 4—Considering Temperature, Supply and Device 
Variations: The next step is to take the above “optimum” 
filter and simulate variations in gain induced by temperature, 
supply and processing. This is accomplished with the same 
disk simulator setup as in step 3. To simulate these varia- 
tions, the designer need only vary the pump resistor’s value. 
This will affect the open loop gain identically to device varia- 
tions. The above tests should be re-run with a minimum and 
maximum resistor. If the performance “‘falls-off-a-cliff” then 
some compromises and adjustments to the filter may be 
required. 


For relatively small temperature ranges a resistor variation 
of +10-15% should be adequate. For full 0°-70° simula- 
tion, resistor variation of +20% is a more accurate reflec- 
tion of the DP8473 performance. If for some reason the 
performance of the data separator cannot be maintained at 
the desired window margin, then trimming the pump resistor 
may be needed to meet performance over the full process 
spread. 


The final simulation involves varying the delay line length. It 
is possible to simulate variations in the delay line by forcing 
a leakage current onto the filter pin (at the VCO input) using 
a pull up or pull down resistor. This leakage current will 
cause a phase error within the loop and will cause the loop 
to act as if the delay line length were changed. Before actu- 
ally running dynamic window margin tests, the designer 
must determine the actual length of the delay line, and then 
adjust this length to the limits specified in the datasheet. 
Then at each limit the dynamic window margin test can be 
performed. : 


In order to measure the length of the delay line a static 
window margin test can be performed. This test uses a disk 
simulator with a format that has ail 0’s or 1’s data fields. 
Within the data field one bit is shifted until the PLL mis-de- 
codes the data. Using the maximum tolerable bit shift num- 
ber, the delay line length can be extrapolated. This same 
measurement can be done with various filter pull up/down 
resistors. By proper resistor selection the limits of the delay 
line length can be simulated. Using these simulated delay 
line techniques a dynamic window margin test can be run, 
and the resultant PLL performance can be characterized. 

Step 5a—Bit Error Rate Measurements: This test is per- 
formed as a verification of the final total system. It consists 
of putting together a complete floppy drive, floppy media, 


separator, and controller system then running long term 
read/write tests randomly across the disk media. For a 
known number of read/writes and the resultant value of 
read errors, a number can be derived that is the ratio of bit 
errors to total number of bits read. This test proves the in- 
tegrity of the entire system, and should be performed over 
some manufacturing spread of products. While this test is 
useful to verify the complete system integration, the data 


' separator is only one small part of the total contribution to 


the total system error rate. 


Step 5b>—Real World Worst-Case Tests: As a final analy- 
sis and proof that the data separator is solid it is often useful 
to test the data separator on a known “worst case” drive 
and disk. Generally the evaluation is done with a disk that is 
recorded off speed and off track. This ensures that a maxi- 
mum amount of bit shift and speed variation is present. The 
main problem is to ensure that the disk still has acceptable 
data. If excessive errors are encountered, evaluation of the 
types of error that are occurring can be used to determine 
whether the bandwidth of the PLL needs to be increased 
(acquisition related errors) or decreased (bit shift related er- 
rors). 


Alternate Simple In-System Data Separator Evaluation 


Provided here are some quick tips on evaluating the data 
separator without any test equipment, but just by running 
long term in-system tests. 


1. If after some initial testing a lot of sector or ID address 
mark or data address mark not found errors are given by 
the controller, then in all likelihood the data separator is 
not locking properly. The bandwidth of the loop should be 
increased, or possibly the loop is too heavily over- 
damped. 


2. If the disk controller is experiencing a large amount of 
address or data field CRC errors, then probably the loop 
is being sent out of lock by bit shift noise. Thus, the gain 
of the loop may be too high or the loop is underdamped. 


5.2 Understanding the Window Margin Curves 


Careful analysis of a window margin curve can yield quite a 
bit of information about the data separator characteristics. 
Figures 18a, b, and c show some typical window margin 
plots. These curves were made using a disk simulator that 
outputs a “reverse write precompensated”’ bit shift pattern 
to the data separator. 


These curves plot the maximum bit shift tolerance (vertical 
axis) versus motor speed variation (MSV-only) (horizontal 
axis). The controller was programmed to perform a repeti- 
tive single sector read, while the simulator outputs a format- 
ted track at the programmed MSV and bit shift amount. All 
the data read with MSV and bit shift amounts that fall under 
and within the curve (shaded area) can be consistently read 
correctly. All data read with MSV and bit shift amounts out- 
side and above the curve either could not be correctly locat- 
ed by the controller, or had errors in it. 


The first thing to note is that as the MSV variation from the 
nominal frequency increases, there is a point at which the 
PLL performance drops to zero bit shift (the vertical lines of 
the curve). This is an indication of the lock range of the PLL. 


Thus for Figure 18a the lock range is —8% to + 10%. This 
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asymmetry in the lock range is typical of the DP847x series 
PLLs and is due to a slight skew in the charge pump. This 


skew adds some bit shift rejection improvement. Figure 18b 
has a lock range of -7% to +9%, while Figure 18c has a 
much wider lock range of nearly +12%. This is an indica- 
tion of the loop bandwidth. Here Figure 18a has the lowest 
bandwidth, then Figure 18b, and finally Figure 18c has the 
highest bandwidth. 


Another characteristic of each of these curves is the down- 
ward slope in the positive MSV direction. The start of this 
Slope is the point at which the delay line becomes longer 
than the 4 period of the data rate. For example, in Figure 
18a the slope starts at about 0 MSV (ignoring the dip at zero 
MSV for the moment which is due to some internal noise). 
This indicates that the delay line is a quarter period of the 
nominal data rate. Unfortunately, this causes a degradation 
in performance at higher MSV. In Figure 78b the slope 
Starts at about +3%-4% MSV, and so the delay line is 
about 3%-4% short at a nominal data rate. This is an opti- 
mal delay line length to maximize performance over a 
+6%-8% lock range. In Figure 18c the delay line is about 
3%-4% too long and so there is quite a bit of degradation 
in window margin in the + MSV portion of the curve. 


A final observation is that the wider the bandwidth the lower 
the window margin, assuming other things like data rate re- 
main constant. 


Another interesting fact to note is the type of errors that 
occur when the bit shift/MSV exceeds the PLL perform- 
ance. Generally to the left or right of the curve (extreme 
MSV) the controller will give ‘Address Mark not Found” er- 
rors which is an indication of the PLLs’ inability to lock prop- 
erly. Errors for bit shift that exceeds the curve but for MSV 
within the PLL’s lock range are generally CRC errors, al- 
though at very high bit shift a mixture of CRC and Address 
Mark Errors are expected. 
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5.3 DP8473 Filter Switching Design Considerations 


Due to the desire to handle multiple data rates, the DP8473 
incorporates on-chip data rate selection logic, and also filter 
switching logic. In this section we will discuss how this logic 
works and how to design a set of filters to maximize per- 
formance at various combinations of data rates. 


Designing with a Single Filter 


Previous design examples have dealt with optimization of a 
single filter at a single data rate. If the DP8473 is to be used 
at one data rate, the circuit connection is shown in Figure 
19, and its design is straight forward. It is possible to use a 
single filter and obtain a reasonable performance at two 
data rates (i.e., 250 Kb/s and 500 Kb/s or 500 Kb/s and 
1 Mb/s). This can be accomplished since the loop band- 
width is scaled by the PLL’s divider. Since the divider value 
increases by a factor of two when going from the high to the 
low data rate, the bandwidth scales by: 


_ @n500 
@n250 — 2 


This scaling is probably not enough to optimize the lower 
data rate and the damping is affected too, but the single 
filter approach can still provide acceptable performance in 
many instances. 


C1 
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FIGURE 19. DP8473 Filter Configuration for a Single Data Rate Filter, 
May Be Used as Compromise Filter for Any Two Data Rates 
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Designing for 250K/300K/500K MFM | 


This next filter configuration allows fewer compromises (and 
hence better performance) when using all 3 PCAT data 
rates. This configuration is shown in Figure 20. This circuit 
uses two pairs of R’s and C’s that compose two indepen- 
dent filters. One filter is connected to the FGND250, and the 
other to FGND500. 


To implement the design of Figure 20, first design single 
optimum filters at 250 Kb/s, 300 Kb/s, and 500 Kb/s. Use a 
single pump resistor for all data rates. Verify and tweak the 
performance of these filters individually. The 500 Kb/s filter 
can be directly used. The 250 Kb/s and 300 Kb/s individual 
filter values need to be compromised into a single R and C 
filter. C; should be 1/20th of Co, and if desired C3 can be 
added with a value that is 1/20 of Cy. 


Designing for 1.0 Mb/s and a 2d Data Rate 


By adding an additional capacitor to Figure 19 1.0 Mb/s 
data rate can be supported, as shown in Figure 27. \n this 
figure a single damping resistor is used, but depending on 
the chosen data rate, one or both capacitors is selected. 
This configuration allows the bandwidth to be adjusted more 
flexibly when designing for the various data rates. The de- 
sign process is, however, a little more complex. 


To implement the design of Figure 27, first design single 
optimum filters at 1.0 Mb/s and 500 Kb/s (or 250 Kb/s). 
Use a single pump resistor for all data rates. Verify and 
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tweak the performance of these filters individually. Using 
these values, choose a value for Ro (damping resistor) that 
is a good compromise for all data rates. Next choose Co to 
be the optimum value from the initial individual design verifi- 
cation of the 1.0 Mb/s design. Next choose Cg such that the 
sum of Co and Cg equals the value for the optimum 
500 Kb/s (or 250 Kb/s) design. Finally, choose Cz to be 
1/20th of C3. 


Designing for All Possible Data Rates 


To support all possible data rates the simplest circuit config- 
uration is one similar to Figure 20, but with an additional 
capacitor selected for the 1 Mb/s data rate. 


To implement the design of Figure 22, first design single 
optimum filters at 250 Kb/s, 500 Kb/s, (800 Kb/s also if 
needed), and 1 Mb/s. Use a single pump resistor for all data 
rates. Verify and tweak the performance of these filters indi- 
vidually. Using all of these values, choose a value for Ro 
(damping resistor) that is a good compromise for all data 
rates. Next choose Co to be the optimum value from the 
initial individual design verification for 1 Mb/s data rate filter. 
Next choose C3 from the 500 Kb/s initial design. Cg should 
be chosen such that Co+C3 equals the optimum 500 Kb/s 
filter value. Then the 250 Kb/s (and 300 Kb/s if used) filter 
capacitor, C4, must be chosen in a similar manner. C, 
should be chosen such that C, + Co equals the optimum 
250 Kb/s filter capacitor value, or if using 300 Kb/s it must 
equal the best compromise 250/300 Kb/s filter capacitor. 
C; should be chosen to be 1/20th of Co. 
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FIGURE 20. DP8473 Filter Configuration for Optimum 250/300/500 Kb/s (2 Filter) Design 
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FIGURE 21. DP8473 Filter Configuration for a Slight Tradeoff Filter Design at 1 Mb and 500 Kb/s 
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FIGURE 22. DP8473 Filter Configuration for All Data Rates 
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The previous filter does, however, have some minor per- 
formance tradeoffs if all data rates are to be implemented. If 
the best performance is desired, then the configuration 
shown in Figure 23 should be used. In this figure, 3 individu- 
al filters are used for each of the data rates. The 1.0 Mb/s 
filter must be switched via some external circuitry, labeled 
“ground switch” in the figure. The circuit should enable this 
filter only when 1 Mb/s data is used, and this filter should be 
disabled when any other data rate is needed. The circuit to 
accomplish this could be as simple as an open collector 
gate derived from the RPM/LC pin, or an alternative that 
uses no additional hardware is to use an unused drive select 
output. If the latter option is chosen, then software will have 
to select the 1 Mb/s filter prior to using this data rate by 
enabling this bit in the Drive Control Register. 


The design of this filter network is very straightforward. Sim- 
ply design and optimize each filter individually, and use 
these filter values directly. (Again if 300 Kb/s is also used 
the 250 Kb/s filter used will be a compromise between the 
optimal 250 Kb/s and 300 Kb/s filters derived individually.) 


5.4 DP8473 Oscillator Design 


Figure 24 shows the schematic of the crystal oscillator used 
on the floppy disk controller. This circuit consists of a simple 
inverter whose impedance has been optimized for use as an 
oscillator. The inverter is biased into its linear operating re- 
gion by a high value (>1 MQ) resistor that is in parallel with 
the crystal. This biasing allows the inverter to operate as a 
simple inverting linear gain element. 
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FIGURE 24. Simplified Schematic of 
Oscillator Circuit for DP8&473 


The DP8473 oscillator is intended to be used with a funda- 
mental mode parallel resonant crystal. The only external 
components required are the crystal and two external ca- 
pacitors. These capacitors are usually. very small (picofar- 
ads). 
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FIGURE 23. Filter Configuration for Optimal Filter Design at All Data Rates 


TABLE II. Important Parameters for Crystal Selection 


| __Grystal Frequency | 24M 


<1000 
Shunt Capacitance 


External Parallel 
10 pF 


Capacitors 

(include parasitics) 
Table Il shows the important parameters to check for when 
selecting a crystal to use with the DP8473. While the recom- 
mended resonance mode is parallel, a series resonant crys- 
tal can be used. It will just oscillate in parallel mode 30 
ppm-300 ppm from its ideal frequency. 


lf an external oscillator circuit is used, it must have a duty 
cycle of at least 40%-60%, and minimum input levels of 
2.4V and 0.4V. The controller should be configured so that 
the clock is input into the OSC2 pin, and OSC1 is tied to 
ground. 


5.5 Trimming for Perfection 


The integrated data separator was designed to achieve ex- 
cellent performance. However, product, temperature, and 
power supply variations can degrade performance some- 
what. This can lead up to a 10% variation in window margin 
performance. While this is still exceptional for any analog 
design, it is possible to trim out this variability. 


The two major factors that contribute to data separator per- 
formance degradation are: 1) Loop Gain variation; 2) 1/, pe- 
_ riod delay line length variation. 


Trimming the Loop Gain 


The loop gain variation can be trimmed by replacing the 
pump resistor, Ry, with a variable resistor. This resistor 
should be trimmed based on the ideal lock range of the PLL 
desired. For example, if a +6% lock range is desired, then 
during final board product test, a tester can be used to mea- 
sure the total lock range and Ry can be adjusted larger to 
reduce lock range, or smaller to increase it. 


Trimming the Quarter Period Delay Line 


The perceived length of the quarter period delay line can be 
modified by causing a static phase error in the loop to com- 
pensate for the quarter period delay line’s error. This is ac- 
complished by placing a pull up or pull down resistor on the 
filter pin. This resistor can be adjusted by measuring the 
Static Window margin for both an early and late single bit 
shift. Based on these measurements the delay line can ef- 
fectively be adjusted by changing the value of the filter pull 
up/down resistor. 


5.6 Initially Uniocked Model 


This section is provided in order to complete the full discus- 
sion of the theoretical operation of a data separator. It is 
useful to discuss how the controller locks back to the crys- 
tal/clock reference when it needs to. This operation is taken 
care of by the controller so that the user need not concern 


himself with the design aspects of this section. However, if 
the user desires a more complete understanding of the en- 
tire lock process that the data separator goes through, this 
section is presented. 


Another model is used to analyze the behavior of the PLL in 
an unlocked state. It is assumed in this model that the loop 
is not locked, and the VCO frequency is different from the 
input frequency. This model can be used to evaluate how 
the PLL re-locks to the reference clock after reading bad 
data and being thrown off frequency. 


The first operation of the PLL is to frequency lock, so for this 
model each block is described as a function in terms of 
frequency, not phase. An equation can be derived for the 
frequency error that is similar to equation (2) for the phase 
error: ~ 3 

cL eee eer 
4, [1 + Kpge K’ycoF(s)] 
In the initially unlocked model, the phase detector has a key 
role. The phase detector compares the VCO output with the 
input signal. If the VCO output rising edge is leading the 
input signal, a pump-down signal is generated from this 
edge of the VCO to the next rising edge of the input signal. If 
the VCO is lagging the input signal, a pump-up signal is 
generated from the edge of the input signal to the rising 
edge of the VCO. 


There is no overshoot of the VCO frequency. Only one type 
of pump signal is generated, up or down, to bring the VCO 
frequency toward the input frequency. For example, if the 
VCO frequency is higher than the input frequency, only 
pump-down signals are generated. It can also be seen that 
the larger the frequency difference between the VCO and 
the input, the longer the pump pulses become. The average 
current flowing from the charge pump is roughly proportion- 
al to the frequency difference of the signals at the input of 
the phase (and now also frequency) detector. The phase 
detector gain is: 


(26) 


IPUMP 
Kp-¢ = — 27 
DF =O (27) 
for wo < 2w1, where Aw = wo — a4, and 
Kor = —lpumP (28) 


for wo > 204. Therefore, if wo is not too far from w 4, the 
expression (8) can be written for our PLL as: 


sAw Co 
K’vco !pump 
AwC 
1+s (Re Co + ed 
K’vco lpump 
This expression will allow the calculation of the time that the 
loop requires to lock back to the reference after a read op- 
eration goes through a bad data field or write splice. 


Ke(s) = (29) 


Acquisition to the Crystal 


After the completion of a read attempt, it is important to 
ensure that under the worst case conditions the PLL will 
properly re-lock itself to the reference clock. In order to 
achieve the required performance during the acquisition to 
the data stream, the PLL must have reached the lock to the 
crystal before it is allowed to lock back to the data. 
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lf the PLL attempts to lock to a write splice the VCO may be 
pulled way off frequency. To prevent this, read gate should 
be deasserted as soon as a wrong or bad data field is de- 
tected. This will prevent the VCO frequency from being 
pulled too far away. The DP8473 read algorithm has been 
optimized to prevent this. 


if the PLL is locked to the data stream, when read gate is 
deasserted, the lock mechanism to lock back to the refer- 
ence frequency is quite similar to locking to the data. If the 
frequency of the VCO has been swept way off frequency 
because of a bad data field, noise, write splice, or missing 
data, the unlocked PLL model must be used. Since when 
locking to the crystal the phase-frequency comparison is 
always enabled, the phase detector acts as a frequency 
discriminator. Switching to the crystal imposes a frequency 
step to the PLL. It can be demonstrated that the frequency 
error generated is an exponential function of time, going to 
0 with the time constant of: 


(30) 


Thus Tp can be assumed to be the worst case acquisition 
time to the reference clock. 


Example 3: From the previous example 1, we have chosen 
the values for the components of: Co = 
0.039 pF, Ro = 53529. We would like to find 
the worst case time required to re-lock to the 
crystal. Assume that the maximum frequency 
range of the VCO is +30%. 


If the VCO is pulled 30% off center, then: 
Aw = 277(500 kHz) (0.30) = 942 Krad/sec 


Using equation (10) for example 1, we can ob- 
tain: 


Tp = (0.039 pF)(5450) 
(0.039 1)(942K)(5.6KM)(8) 
(75 Mrad) 
Tp = 41 ys 


This is about 4 byte times. Thus, read gate 
must be deasserted for this length of time be- 
fore re-asserted to assure that the PLL has re- 
locked to the reference. Most floppy control- 
lers de-assert read gate much longer than this, 
and the DP8473 deasserts its internal read 
gate for 6 bytes. 
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Design Guide for DP8473 in 
a PC-AT 


OVERVIEW 


When designing a floppy interface circuit for a PC-AT in the 
past, there was very little flexibility given to the design engi- 
neer. The NEC765, which was designed into the original 
IBM PC, was the only floppy controller available that would 
guarantee compatibility. Compatibility is extremely important 
in a PC design. 


There were many design issues that had to be resolved 
when using the NEC765 to produce a fully functional floppy 
controller interface. A data separator had to be selected or 
designed. A write precompensation circuit needed to be in- 
cluded. A whole score of miscellaneous logic had to be de- 
signed to handle all of the unique PC functions that the 
NEC765 does not handle itself. 


The DP8473 from National Semiconductor was developed 
to eliminate all of these design problems. All of the extra 
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functions and logic normally required for an XT or an AT 
design were included inside the chip. Even an analog data 
separator, which is classically the hardest function to de- 
sign, has been integrated into the DP8473. 


Compatibility has been completely retained. The DP8473 is 
software compatible with the NEC765A. We have not found 
any current software available for the PC that fails to work 
properly with the DP8473. This includes software running 
under DOS and OS/2. 


This application note will discuss some of the issues in- 
volved in a floppy controller design with the DP8473. Even 
though on the surface, there may not seem to be many 
options when designing a floppy controller for a PC, there 
really are quite a few. Some of these options include: signal 
swapping in the floppy cable, different types of floppy 
drives, and data separator filter selection. 
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FIGURE 1. Schematic of Typical DP8473 Floppy Controller Design 
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HARDWARE ENVIRONMENT 


A typical floppy controller design with the DP8473 will look 
something like the schematic shown in Figure 7. You may 
be surprised that the entire schematic for the floppy control- 
ler design fits on less than one page. Especially if you con- 
sider that the schematic for a similar function in the IBM 
PC-XT technical reference manual takes four full pages. 


The heart of the design is, of course, the DP8473. Most of 
the interface pins to and from the DP8473 go directly to the 
peripheral bus or the disk drive cable without additional logic 
or buffering. 


DRIVE CABLE INTERFACE 


The DP8473 disk interface signals connect directly to the 
drive cable.’ Most disk drives terminate the drive cable with 
resistors. Termination is required because the output buffers 
of the floppy controller are open-collector. 


Terminated signals are used because historically, relatively 
long cables have been used to connect the floppy controller 
to the disk drives. The cable termination will decrease the 
amount of crosstalk and noise on the drive cable signals. 


A typical disk interface circuit consists of an open-collector 
output buffer at the signal source, and a termination resistor 
and a Schmitt input buffer at the signal destination. For ex- 
ample, the STEP output pin on the DP8473 is an open-col- 
lector output buffer that is capable of sinking up to 48 mA 
(See Note 1). If the output is off, the buffer is disabled, and 
the termination resistor on the disk drive will pull the signal 
high. If the STEP output is on, the DP8473 buffer will pull the 
signal low. An example of the cable termination logic is 
shown in Figure 2. 


DP8473 Disk Drive 


#5 


Floppy Drive Cable 
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Note 1: The DP8473 actually contains open-drain output buffers due to its 
CMOS design. The end result is the same as TTL open-collector buffers. 


FIGURE 2. Example of Buffers and Terminators 
Used for Floppy Drive Interface 
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The termination resistors used with 5.25” drives or 
8” drives typically have a value of 1502. With this resistor 
value, the output buffers must be capable of sinking about 
35 mA each in order to pull the drive signal to a logic low 
level. The DP8473 is able to sink this current without exter- 
nal buffers. 


The termination resistors used with 3.5” drives are often 
1 kQ. 1 kO termination resistors are also sometimes found 
on low power 5.25” drives. Drive manufacturers have rec- 
ognized that the floppy interface cable used in a PC is rela- 
tively short. Also, the drives are installed in the same 
grounded enclosure as the PC and the floppy controller. 
This reduces the amount of noise introduced on the floppy 
interface cable. 


If both 3.5” drives and 5.25” drives are to be used in an 
application, the termination resistors used with the DP8473 
must be chosen carefully. The termination resistor value 
used with the DP8473 must be the larger of the termination 
resistors used on the drives. For example, if the 5.25” drive 
has 1502 termination resistors and the 3.5” drive has 1 kO 
termination resistors, the termination resistors used on the 
inputs to the DP8473 should be 1 kQ. 


The termination resistors for the inputs to the DP8473 
should be placed near the DP8473. The termination resis- 
tors for the outputs for the DP8473 to the disk drive are 
contained in the disk drive itself. 


Additional disk interface buffering is not normally required 
when using the DP8473. It can sink up to 48 mA for each 
disk output signal. This is more than enough capacity for a 
typical floppy design. 


DRIVE CONFIGURATION 


A PC-XT can typically interface to up to four disk drives. A 
PC-AT, however, is usually limited to two disk drives. The 
two drive limitation is due to the ROM BIOS used in most 
AT’s. More than two drives can be used if special software 
drivers are written. 


The connection between the floppy drives and the floppy 
controller in a PC is slightly different than the SA450 stan- 
dard used in non-PC’s. The advantage to the method used 
in a PC is that each disk drive installed in the PC can be 
configured identically. Even the Drive Select strap is the 
same. Each drive is configured as drive 1 (or B). Even if four 
drives are all connected, they are each strapped as drive 1. 


The trick used to accomplish this feat is cable wire swap- 
ping. The drive cable is cut up and wires are moved around. 
The cable swapping re-routes the four DRIVE select signals 
(DRO, DR1, DR2, DR3) to the DR1 signal of each individual 
drive. For example, DRO is routed to drive A’s DR1 input. 
DR1 is routed to Drive B’s DR1 input, and so on. In a similar 
manner, the cable swapping also re-routes the four MOTOR 
signals (MTRO, MTR1, MTR2, MTR3) to the MOTOR signal 
of each drive. Figure 3a demonstrates how the cable is con- 
figured for two floppy disk drives. A second cable would be 
used if more than two drives are required as shown in Figure 
3b. 
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FIGURE 3a. Cable Swapping Used for Drives A and B 
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FIGURE 3b. Cable Swapping Used for Drives C and D 


Note: The asterisk (*) next to DR1 indicates that this drive is strapped as 
Drive 1. In the PC, all drives are strapped as Drive 1. 

If more than one disk drive is attached to the floppy control- 
ler, there may be more than one drive terminated. This may 
Cause a current overloading problem. The controller may 
not be able to drive an active signal low. 


It is easy to prevent current overloading in a two disk drive 
PC. Simply make sure that only one drive is terminated. 
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Ideally the terminated drive should be the drive at the end of 
the drive cable, although it could be either drive. 


If both drives are terminated, the output buffers will be driv- 
ing too much current. The system will be out of specifica- 
tion. This is a common situation and is largely ignored by PC 
manufacturers. The output buffers can usually handle the 
additional load. 


It three or four drives are to be used, things become more 
complex. For example, if four 1502 terminated drives are all 
attached to the DP8473, the DP8473 will have to sink 
139 mA for each drive interface signal. The DP8473 is guar- 
anteed to sink up to 48 mA. Therefore, this configuration 
would not work without additional buffering. Please refer to 
the How to Calculate the Maximum Current Required for 
Output Buffers section for a description on current calcula- 
tion. 


There are three techniques that can be used to prevent 
overloading the output buffers: 


Technique 1: 


Using larger termination resistors can reduce the load on 
the DP8473 to acceptable levels. If 1 kN resistors can be 
used instead of 1500 resistors. In the worst case where all 
four disk drives are terminated, only 21 mA will be generat- 
ed instead of 140 mA. This is well within the specification of 
the DP8473. 1 kO resistors are commonly used with 3.5” 
drives. 


Technique 2: 


The most direct technique that can be used is simply adding 
additional buffers for the extra disk drives. Drives A and B 
can be driven directly by the DP8473. The outputs to drives 
C and D can pass through an open-collector buffer such as 
the 7407. This is shown in Figure 4. 1k pullup resistors are 
required for some of the DP8473 outputs because they are 
not terminated by drives A or B. 
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FIGURE 4. Extra Buffers Required 
for Four Drive System 
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Technique 3: 


Daisy chain the floppy drives with the controller on one end 
of the drive interface cable, and one terminated drive at the 
other end. One to three additional non-terminated drives 
can be added in the middle as shown in Figure 6. With this 
technique, the four Motor signals from the DP8473 should 
be wire-ORed together as shown in Figure 5. Each drive 
must be strapped for the proper drive select (0-3). 
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FIGURE 5. Wire OR Required 
for Daisy Chain Connection 
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How to Calculate the Maximum Current 
Required for Output Buffers. 


Since a floppy controller design may not work cor- 
rectly due to current overloading, it is important to 
understand exactly how to calculate the maximum 
current required by the floppy controller for each 
output signal to the disk drive. This is largely deter- 
mined by the termination resistors used by the disk 
drives. A formula that can be used is: 


(Voc) + (Max Vcc Variation) — (Vo_(max) 
(Termination Resistor) © ~ (1 — Resistor Accuracy) 


Voc = 5.0 
Max Vcc Variation = Power supply variation (0.5V) 


VoL(Max) = Maximum active low output voltage of buff- 
er (0.8V) 


Termination Resistor = Termination on disk drive 

N = Number of terminated disk drives 

Resistor Accuracy = Accuracy of termination resistors 

(10% or 0.10) 

Example 1: 

One terminated drive with 150 termination resistors. 

5.0 + 0.5 — 0.8 
150¢1°0.9 


Example 2: 
Four terminated drives with 1k termination resistors. 
5.0 + 0.5 — 0.8 


= 34.8 mA 


7 = 20.9mA 
1000 e Z ©0.9 


Resistor Pack 


a | 


Terminated 
Drive 
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FIGURE 6. Daisy Chain of Four Drives 
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DRIVE TYPES 


There are many types of disk drives that can be connected 
to the DP8473 floppy disk controller. The DP8473 is com- 
patible with 8”, 5.25", and 3.5” floppy disk drives, although 
8” drives are rarely used today. 


Other types of peripherals may be connected to the floppy 
controller as well. A streaming tape drive that is used to 
back up the hard disk is often connected to the floppy con- 
troller. A tape drive of this type is very specialized. It has 
been designed to look like a floppy disk drive from an elec- 
trical interface point of view. It does not perform exactly like 
a disk drive, however. Special software is usually required to 
make it work correctly. The STEP signal is often used to 
issue Commands to the tape drive. For example, to rewind 
the tape, four step pulses may need to be issued. To start a 
read, six step pulses might be issued. 


All of these different drive types have one thing in common, 
a similar electrical interface. This allows them all to be con- 
nected to a common drive interface cable. For example, the 
READ DATA signal on pin 30 of the floppy interface cable is 
the MFM encoded serial stream of data from the disk. The 
INDEX signal on pin 8 of the cable identifies the beginning 
of a track. 


However, there are some minor differences between drive 
tapes that must be considered. The DENSITY signal is a 
good example of a difference. This signal is active for high 
density transfers on a dual density 3.5” drives. But, this 
signal is active for /ow density transfers on a dual density 
5.25” drive. This difference makes the floppy system design 
more complex when 5.25” dual density and 3.5” dual den- 
sity drives are both used in the same PC. 


- DP8473 


The DP8473 has a signal called RPM/LC that normally con- 
nects to the Density or Low Current input on a dual density 
5.25” drive. lf a 3.5” drive is used, the RPM/LC output 
should be inverted. 


A design such as the one shown in Figure 7 could be used 
to create the proper DENSITY signal for both 5.25” and 
3.5” drives. The jumpers and logic allow the user to select 
between drive types for each individual drive. 


Another solution is simply to use a 3.5” drive that contains a 
built-in jumper to vary the polarity of the DENSITY signal 
directly on the drive. This option eliminates the need for 
external logic and jumpers. 


Another signal that is drive type dependent is DISK 
CHANGED. This signal exists on low and dual density 3.5” 
drives and also on dual density 5.25” drives. It does not 
exist on low density 5.25” drives. If a low density 5.25” 
drive is to be used, the DISK CHANGED signal should be 
held active (low level). It may be held active by the drive by 
itself. If not, a pull-down resistor could be used to activate 
the non-driven signal. 


One thing to consider while choosing drive types is media 
compatibility. Of course, you can’t put a 3.5” disk in a 5.25” 
drive. But, there are more subtle incompatibilities even with- 
in similar media types. For example, a low density 5.25” 
disk written to in low density mode by a dual density drive 
cannot be read reliably by a low density drive. Table | lists 
the compatabilities between different drives and media 


types. 


Density 


To Floppy 
Drive Cable 
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FIGURE 7. Density Select Logic for 5.25” or 3.5” Drives 
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Drive Type 
3.5” LD,HD 


5.25” LD 


5.25” LD,HD 


Notes: 


LD = Low Density 

HD = High Density 

R/W = Readable & Writable 
R Only = Readable Only 


DATA RATES 


Different drive types may use different data rates. The data 
rate is specified by the number of bits that are transferred in 
a second. For example, 250 kb/s is translated to 250 thou- 
sand bits per second. 


The data rate used by a disk drive is determined by the 
electronics of the drive and the specifications of the media. 
Low Density media require data to be transferred at 
250 kb/s. High Density media is twice as fast at 500 kb/s. 


There is a complication with Low Density 5.25” media in a 
Dual Density drive. The 5.25” Dual Density drive spins the 
disk faster (360 RPM) than a Low Density drive (300 RPM). 
When a Low Density disk is read from a Dual Density drive, 
the data rate will be 300 kb/s instead of 250 kb/s because 
of the rotational speed difference. 


The DP8473 can operate at all the data rates required for a 
PC. This includes 250, 300, and 500 kb/s. In addition, the 
DP8473 can operate at 1 Mb/s. This high data rate is start- 
ing to appear in both floppy disks and streaming tape drives. 


p»P INTERFACE 


It is hard to imagine how the interface between the DP8473 
and the »P bus could be made any simpler than it is. Only 
one interface function is not integrated in the DP8473. That 
function is address decoding. The typical ~P connections 
are shown in Figure 8. 


The DP8473 requires a CS (chip select) enable signal that is 
generated elsewhere. Typically, this could be generated by 
an ALS521 8-bit comparator or a similar circuit. Address 
decoding of the three least significant bits of the address is 
performed by the DP8473. The AEN (address enable) signal 
from the P bus should be included in the CS logic. This will 
prevent DMA transfers from generating a CS. 


The eight bit data bus from the DP8473 connects directly to 
the data bus of the uP. Bus transceivers are not required 
because 12 mA buffers are built into the DP8473. 


The IOR (I/O read), |IOW (I/O write), RESET, TC (terminal 
count), DRQ (DMA request), and IRQ (interrupt request) sig- 
nals can be connected directly to the DP8473. No additional 
buffering or gating is required. The logic required to 
TRI-STATE® the DRQ and INT pins is integrated in the 
DP8473. 


35" LD 720k 
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TABLE I. Drive and Media Compatibility 


Media Type 


CS 


Address 
(3F0=3F7) 


Decoder 


DP8473 


(ALS521) 
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FIGURE 8. P Interface to DP8473 


FILTER SELECTION 


The internal data separator in the DP8473 requires an exter- 
nal filter to operate correctly. This filter is part of an analog 
Phase-Locked Loop (PLL) that is used by the data separator 
integrated into the DP8473. This is commonly referred to as 
an analog data separator due to the analog nature of the 
PLL’s filter and Voltage Controlled Oscillator (Vco). 


As the floppy controller changes from one data rate to an- 
other, the filter used by the PLL must change also. This is 
done automatically in the DP8473. Two or three filters are 
connected externally to different pins of the DP8473. The 
correct filter is selected and activated by the DP8473 itself. 


The filter selection is performed by grounding or forcing 
TRI-STATE the appropriate filters. For example, a two-filter 
arrangement is shown in Figure 9. \f 500 kb/s is selected, 
the FGND500 pin is grounded and the FGND250 pin is at 
TRI-STATE. From the filter pin’s point of view, this appears 
as filter F2 in parallel with capacitor C1. F1 is electrically out 
of the picture. When 250 kb/s is selected, it is the opposite. 
The FGND500 pin is at TRI-STATE and the FGND250 pin is 
grounded. Since 300 kb/s data rate is close to 250 kb/s, 
the same filter is used for both data rates. 


The two-filter arrangement shown in Figure 9 would be used 
in most PC applications. It supports 250, 300, and 500 kb/s 
data rate. Other filter combinations may be used for special- 
ized applications. These filter combinations are described in 
the DP8473 data sheet. 


DATA SEPARATOR PERFORMANCE 
One of the most important features of the DP8473 is the 


high level of data separator performance. This performance | 


translates directly to reduced disk |/O errors. There is quite 
a bit of information that can be discussed on data separator 
performance. A lot of this information is presented in an 
application note titled “Floppy Disk Data Separator Design 
Guide for the DP8473, AN-505”. 


It might seem desirable to specify the maximum error rate of 
the DP8473. This could be expressed in terms of the num- 
ber of bits that can be read correctly before an error occurs 
(1012, for example). This is not a practical parameter to 
specify, however. One problem is the amount of time this 
type of measurement would take. A test of 1012 could take 
well over 400 days to measure. 


Another problem is defining the test conditions. Is the test 
performed under ideal disk conditions? Are bits jittered or is 
motor speed variation simulated? There are so many vari- 
ables in this type of a test that it would be difficult for two 
different people to produce the same results. In addition, 
the error rate is related to other factors beside the DP8473 
such as the disk drive or the floppy media. 


DP8473 
Floppy Disk 
Controller 


There are many different types of measurements that can 
be made with a data separator. Most of these measure- 
ments indicate how well only one particular section of the 
data separator performs. For example, the gain of the VCO 
(Voltage Controlled Oscillator) or the accuracy of the 1/, pe- 
riod delay line. They don’t, however, give a good indication 
of how well the data separator will perform under real-life 
conditions. 


There is one measurement that produces meaningful data. 
This measurement is called “Dynamic Window Margin’. Dy- 
namic window margin attempts to indicate total data separa- 
tor performance under real-life conditions. It measures how 
much bit jitter the data separator can handle while reading a 
worst case data pattern (DB6 hex) with a drive that has a 
motor speed of varying accuracy. The data is jittered in a 
manner similar to real world jitter with a reverse write pre- 
compensation pattern. The measurement is taken at the 
worst point over a motor speed variation of +6%. An exam- 
ple of a dynamic window margin measurement is shown in 
Figure 10. 


The typical dynamic window margin is specified in the 
DP8473 data sheet. National Semiconductor has made 
measurements of the dynamic window margin of many data 
separators, and the results show that no other data separa- 
tor performs as well as the DP8473s. 


250K/ 
300K 


Filter 
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FIGURE 9. Typical Filter Connection for 250, 300, and 500 kb/s 
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FIGURE 10. Typical Dynamic Window 
Margin for DP8473 


LAYOUT AND COMPONENT CONSIDERATIONS 


The DP8473 contains a combination of digital and analog 
circuitry. Because of the analog nature of the data separa- 
tor, some precautions should be taken when designing a 
board with the DP8473. 


A good DP8473 board layout design will distinguish be- 


tween analog and digital, Vcc and Ground. The supply pins" 


used by the digital circuitry are labeled Voc, GNDB, GNDC, 
and GNDD. The supply pins used for the analog data sepa- 
rator are labeled VocA and GNDA. Standard digital decou- 
pling techniques should be used with the digital supply pins. 


This typically involves 0.1 F capacitors connected be- 


tween Vcc and GND. 


The analog supply pins require a bit more consideration 
than the digital supply pins. Any noise or ripple on the ana- 
log supplies will degrade the data separator performance. It 
is recommended to minimize this noise as much as possi- 
ble. Less than 50 mV noise would be good. 


There are many methods that can be used to minimize 
noise on the analog supply pins. One of the best methods is 
a 5.0V voltage regulator dedicated to the analog section. 
This guarantees a very clean signal. The voltage regulator 
can be driven by the 12V power supply. 


Another method is to place the DP8473 on the board close 
to the entry point of the power supply. At the very least, 
separate supply lines should be dedicated from the power 
supply entry point to the DP8473 VccA and GNDA. 


In addition to the analog supply, any noise or crosstalk intro- 
duced to the external filters will adversely effect the per- 
formance of the data separator. The data separator filters 
should be positioned as close as possible to the DP8473. A 
ground plane surrounding the filters would also be advisa- 
ble. The resistor attached to the SETCUR pin should also 
be close to the DP8473. 


If a 24 MHz crystal is used, it should be placed close to the 
DP8473 as well as the 10 pF capacitor attached to both 
sides of the crystal. 


The component types and tolerances may also effect the 
data separator performance. The accuracy of the resistor 
attached to the SETCUR pin is important. It should have a 
1% tolerance rating. A 5% could be used, but the accuracy 
may effect the data separator performance. 


The capacitor in series with the resistor attached to the FIL- 
TER pin is also critical. It should have a 5% tolerance. The 
series resistor in the same network is not as critical as the 
SETCUR resistor. Therefore, a normal 5% tolerance can be 
used here. 


Finally, the capacitor in parallel with the filter network can 
be rated as low as 10%-20%. It does not effect the data 
separator very much. 


The component tolerances mentioned here are only recom- 
mendations. The DP8473 will work properly with a wide 
range of filter values. These recommendations should be 
followed if data separator performance is an important issue 
in a particular design (which is normally true). 
TROUBLE-SHOOTING 


If the floppy controller does not appear to operate correctly, 
there are some key areas that can be looked at for the 
source of the problem. 


Drive’s in Use light remains on at all times. | 

e Drive Interface cable plugged in backward. 

e Drive Interface signals not properly routed. 
DOS returns a “Not ready error reading drive X”. 


This error can be caused by many different problems. At this 
point it would be best to run the “Floppy Demo Program” as 
described later in this section. 


DOS Directory command returns an old directory. 
¢ Disk Changed signal improperly routed. 

POST produces a “601” error while booting. 

e Drive Interface cable unplugged. 

e Hardware problem with »P interface. 

PC locks up while booting. 

e Hardware problem with ,P interface. 

Parity Error. 

e DMA interface problem. 


Many advanced diagnostics may be used while running the 
“Floppy Demo Program” which is available from National 
Semiconductor. This program allows you to issue individual 
floppy commands such as Read Data, Format Track, and 
Seek. The Result Phase of these commands can be ana- 
lyzed to help determine where a problem exists. The follow- 
ing list describes some likely sources of problems based on 
what is observed with the “Floppy Demo Program’. 


“Missing Address Mark in Address Field”’ error. 


This indicates that the floppy controller could not find any 
valid data on the track being read. No sectors could be 
found. 


e Track has not been formatted. Could be a blank disk. 
The controller does recognize Index Pulses, however. 
This indicates that the drive cable interface is at least 
partially intact. 

e Read Data drive interface signal not properly routed. 

e General data separator problem. See the data separator 
discussion later. 

“Did not receive interrupt” error. 

This is usually accompanied with all FF’s in the Result 

Phase of the command. This indicates that the controller 

could not read anything from the disk drive and Index pulses 

were not.seen. Be sure to reset the floppy controller after 
this error. 

e Disk not inserted in drive or drive door open. 

e Wrong drive selected in command. 

e Drive Interface cable unplugged. 
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MSR (Main Status Register) does not return to 80 —) af- 
ter a reset. 


¢ Floppy controller not inserted in socket properly. 


¢ Hardware problem with address decode (CS) or pP inter- 
face signals. 


¢ Crystal or external clock not operating properly. 

© Floppy controller is bad. 

“No Data” error or “CRC error”. 

® Bad disk media. 

© General data separator problem. 

Fewer bytes read than requested or error in Result Phase. 

e Noise on Reset pin. Insert capacitor between Reset and 
digital GND as specified in the data sheet. 

Long term read produces some errors. 

¢ General data separator problem. 

Many of the problems described above refer to a general 

data separator problem. There are many things that can be 

looked at for data separator problems. 

e Filter wired incorrectly. 

e Incorrect filter component values. 

e Filter layed-out poorly. 

© Too much noise on analog VccA or GNDA. 


FLOPPY CONTROLLER DESIGN WITH NEC765A 


In order to appreciate the amount of circuitry integrated into 
the DP8473, it may be useful to analyze a typical floppy 
controller design for the PC-AT using the standard 
NEC765A floppy disk controller. To simplify the analysis, 
only the block diagram will be presented. The actual sche- 
matic would require many pages. The block diagram is 
shown in Figure 77. 


Address Bus Address 


Decode 


Data 
Bus NEC765 
R/W 
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Rate 
INT 
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The NEC765A was developed many years ago originally for 
8” floppy disk drives. It became very popular because it was 
designed into the original IBM PC. The NEC765A performs 
many functions, but there are also many functions that it 
does not perform. 


A data separator isolates the individual pulses read from the 
disk drive and allows the floppy controller to distinguish be- 
tween MFM clock pulses and data pulses. It typically incor- 
porates an analog PLL. An analog data separator design 
could require as many as 10 chips to design. A single chip 
discrete digital data separator could also be used, although 
the performance will not be as good. 


The write precompensation circuit shifts the MFM encoded 
data as it is being written to the disk. This shifting compen- 
sates for known bit shifts that will occur due to the magnetic 
influences of the individual bits recorded on the disk. This is 
typically designed with a shift register and a multiplexer. 


The NEC765 cannot interface directly to the Drive Interface 
cable. Separate 48 mA buffers are required for each output 
signal. This requires three 7406's, Also, the inputs from the 
disk drive required Schmitt inverters. 


Additional buffering is also required for the 4P data bus. 


The PC-AT requires that the Disk Changed signal be read 
from a particular port. This involves address decoding and 
buffering. 


The only method available to vary the data rate used by the 
NEC765A is by altering the input clock frequency to the 
chip. This must be done with a complex divider circuit that 
generates the different frequencies required for 250, 300, 
and 500 kb/s data rates. 


Due to timing incompatabilities in the NEC765A, the Drive 
Select and Motor On signals must be generated by an exter- 
nal port that is controlled by software. This port also con- 
trols the software reset and DMA and INT enable circuitry. 


Drive 
Control 


Disk 
Changed 


Disk 
Interface 
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Separator 
Write 
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To 
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FIGURE 11. Block Diagram of Floppy Controller Design with NEC765 


5-65 


LES-NV 


t 


AN-631 


DMA transfers must be slowed down due to handshaking 
problems with the NEC765A. This delay is performed with 
an external shift register. 


This entire design easily requires at least a couple of dozen 
chips. The amount of board space used is quite large. A 
considerable amount of current is also consumed. This 
compares to the DP8473 solution which only requires two 
chips. It is easy to see that the DP8473 solution is much 
more economical. 


CONCLUSION 


This design guide was created to answer the most common 
questions encountered while designing with the DP8473. 
Any new design can be based on the information given in 
this guide. A two drive system can be created or more drives 
can be added if required. A variety of disk drives may be 
used including 3.5” drives. 


The address decoding is the only function not integrated 
into the DP8473. However, the integrated data separator 
requires external filtering. which should be carefully layed- 
out on the board. 


If problems arise, there are many items that can be looked 
at to help identify where the problem exists. It may be useful 
to obtain a floppy controller diagnostic program similar to 
the “Floppy Demo Program” available from a National 
Semiconductor sales office. 


If more information is desired concerning the performance 
of the data separator or the trade-offs of designing a custom 
filter for the PLL, please. read the application note titled 
“Floppy Disk Data Separator Design Guide for the 
DP8473”, AN-505. 
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